package.xml000066611532700161006750000042377112272324174010324 0ustar sdk pear.amazonwebservices.com Official PHP SDK for Amazon Web Services. The AWS SDK for PHP enables PHP developers to easily work with Amazon Web Services and build scalable solutions with Amazon S3, Amazon DynamoDB, Amazon Glacier, and more. Michael Dowling mtdowling mtdowling@gmail.com yes Jeremy Lindblom jeremeamia jeremeamia@gmail.com yes Ryan Parman skyzyx ryan@ryanparman.com no 2014-01-29 2.5.2 2.5.2 stable stable Apache 2.0 This release adds support for dead letter queues to the Amazon Simple Queue Service client. 5.3.3 1.4.0 Guzzle guzzlephp.org/pear 3.0.3 curl 2.5.2 2.5.2 stable stable 2014-01-29 Apache 2.0 This release adds support for dead letter queues to the Amazon Simple Queue Service client. sdk-2.5.2/Aws/AutoScaling/AutoScalingClient.php000064411532700161006750000001615712272324172016444 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/autoscaling-%s.php' )) ->build(); } } sdk-2.5.2/Aws/AutoScaling/Enum/LifecycleState.php000064411532700161006750000000163012272324172016666 0ustar '2011-01-01', 'endpointPrefix' => 'autoscaling', 'serviceFullName' => 'Auto Scaling', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'AutoScaling', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AttachInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceIds.member', 'items' => array( 'name' => 'XmlStringMaxLen16', 'type' => 'string', 'minLength' => 1, 'maxLength' => 16, ), ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'CreateAutoScalingGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateAutoScalingGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'LaunchConfigurationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16, ), 'MinSize' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxSize' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'DesiredCapacity' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DefaultCooldown' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'minItems' => 1, 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'LoadBalancerNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LoadBalancerNames.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'HealthCheckType' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 32, ), 'HealthCheckGracePeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PlacementGroup' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'VPCZoneIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'TerminationPolicies' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'TerminationPolicies.member', 'items' => array( 'name' => 'XmlStringMaxLen1600', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 128, ), 'Value' => array( 'type' => 'string', 'maxLength' => 256, ), 'PropagateAtLaunch' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The named Auto Scaling group or launch configuration already exists.', 'class' => 'AlreadyExistsException', ), array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'CreateLaunchConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLaunchConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'LaunchConfigurationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'ImageId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'KeyName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'SecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroups.member', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), 'UserData' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 21847, ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16, ), 'InstanceType' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'KernelId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'RamdiskId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMappings.member', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'DeviceName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'VolumeSize' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 1024, ), 'VolumeType' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'Iops' => array( 'type' => 'numeric', 'minimum' => 100, 'maximum' => 4000, ), ), ), 'NoDevice' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'InstanceMonitoring' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'SpotPrice' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'IamInstanceProfile' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'EbsOptimized' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The named Auto Scaling group or launch configuration already exists.', 'class' => 'AlreadyExistsException', ), array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'CreateOrUpdateTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateOrUpdateTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'Tags' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 128, ), 'Value' => array( 'type' => 'string', 'maxLength' => 256, ), 'PropagateAtLaunch' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The named Auto Scaling group or launch configuration already exists.', 'class' => 'AlreadyExistsException', ), ), ), 'DeleteAutoScalingGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAutoScalingGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ForceDelete' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), array( 'reason' => 'This is returned when you cannot delete a launch configuration or Auto Scaling group because it is being used.', 'class' => 'ResourceInUseException', ), ), ), 'DeleteLaunchConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLaunchConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'LaunchConfigurationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), 'errorResponses' => array( array( 'reason' => 'This is returned when you cannot delete a launch configuration or Auto Scaling group because it is being used.', 'class' => 'ResourceInUseException', ), ), ), 'DeleteNotificationConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteNotificationConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'TopicARN' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'DeletePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeletePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'DeleteScheduledAction' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteScheduledAction', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScheduledActionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'DeleteTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'Tags' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 128, ), 'Value' => array( 'type' => 'string', 'maxLength' => 256, ), 'PropagateAtLaunch' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), ), 'DescribeAccountLimits' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAccountLimitsAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAccountLimits', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeAdjustmentTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAdjustmentTypesAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAdjustmentTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeAutoScalingGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AutoScalingGroupsType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAutoScalingGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AutoScalingGroupNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeAutoScalingInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AutoScalingInstancesType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAutoScalingInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceIds.member', 'items' => array( 'name' => 'XmlStringMaxLen16', 'type' => 'string', 'minLength' => 1, 'maxLength' => 16, ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeAutoScalingNotificationTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAutoScalingNotificationTypesAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAutoScalingNotificationTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeLaunchConfigurations' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'LaunchConfigurationsType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLaunchConfigurations', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'LaunchConfigurationNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LaunchConfigurationNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeMetricCollectionTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeMetricCollectionTypesAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeMetricCollectionTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeNotificationConfigurations' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeNotificationConfigurationsAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeNotificationConfigurations', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AutoScalingGroupNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribePolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'PoliciesType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribePolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'PolicyNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeScalingActivities' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ActivitiesType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeScalingActivities', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'ActivityIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ActivityIds.member', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeScalingProcessTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ProcessesType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeScalingProcessTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeScheduledActions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ScheduledActionsType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeScheduledActions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScheduledActionNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ScheduledActionNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'TagsType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Values.member', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeTerminationPolicyTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeTerminationPolicyTypesAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeTerminationPolicyTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DisableMetricsCollection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableMetricsCollection', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'Metrics' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Metrics.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'EnableMetricsCollection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableMetricsCollection', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'Metrics' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Metrics.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'Granularity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), ), ), 'ExecutePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ExecutePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'HonorCooldown' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), ), ), 'PutNotificationConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutNotificationConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'TopicARN' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'NotificationTypes' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NotificationTypes.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), 'errorResponses' => array( array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'PutScalingPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'PolicyARNType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutScalingPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'ScalingAdjustment' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'AdjustmentType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Cooldown' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MinAdjustmentStep' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'PutScheduledUpdateGroupAction' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutScheduledUpdateGroupAction', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScheduledActionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Time' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Recurrence' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'MinSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DesiredCapacity' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The named Auto Scaling group or launch configuration already exists.', 'class' => 'AlreadyExistsException', ), array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'ResumeProcesses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResumeProcesses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScalingProcesses' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ScalingProcesses.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'SetDesiredCapacity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetDesiredCapacity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'DesiredCapacity' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'HonorCooldown' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), ), ), 'SetInstanceHealth' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetInstanceHealth', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16, ), 'HealthStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 32, ), 'ShouldRespectGracePeriod' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'SuspendProcesses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SuspendProcesses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScalingProcesses' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ScalingProcesses.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'TerminateInstanceInAutoScalingGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ActivityType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'TerminateInstanceInAutoScalingGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16, ), 'ShouldDecrementDesiredCapacity' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), ), ), 'UpdateAutoScalingGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateAutoScalingGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'LaunchConfigurationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'MinSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DesiredCapacity' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DefaultCooldown' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'minItems' => 1, 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'HealthCheckType' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 32, ), 'HealthCheckGracePeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PlacementGroup' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'VPCZoneIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'TerminationPolicies' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'TerminationPolicies.member', 'items' => array( 'name' => 'XmlStringMaxLen1600', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeAccountLimitsAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MaxNumberOfAutoScalingGroups' => array( 'type' => 'numeric', 'location' => 'xml', ), 'MaxNumberOfLaunchConfigurations' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'DescribeAdjustmentTypesAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AdjustmentTypes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AdjustmentType', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AdjustmentType' => array( 'type' => 'string', ), ), ), ), ), ), 'AutoScalingGroupsType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AutoScalingGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AutoScalingGroup', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AutoScalingGroupName' => array( 'type' => 'string', ), 'AutoScalingGroupARN' => array( 'type' => 'string', ), 'LaunchConfigurationName' => array( 'type' => 'string', ), 'MinSize' => array( 'type' => 'numeric', ), 'MaxSize' => array( 'type' => 'numeric', ), 'DesiredCapacity' => array( 'type' => 'numeric', ), 'DefaultCooldown' => array( 'type' => 'numeric', ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'sentAs' => 'member', ), ), 'LoadBalancerNames' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'sentAs' => 'member', ), ), 'HealthCheckType' => array( 'type' => 'string', ), 'HealthCheckGracePeriod' => array( 'type' => 'numeric', ), 'Instances' => array( 'type' => 'array', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'LifecycleState' => array( 'type' => 'string', ), 'HealthStatus' => array( 'type' => 'string', ), 'LaunchConfigurationName' => array( 'type' => 'string', ), ), ), ), 'CreatedTime' => array( 'type' => 'string', ), 'SuspendedProcesses' => array( 'type' => 'array', 'items' => array( 'name' => 'SuspendedProcess', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ProcessName' => array( 'type' => 'string', ), 'SuspensionReason' => array( 'type' => 'string', ), ), ), ), 'PlacementGroup' => array( 'type' => 'string', ), 'VPCZoneIdentifier' => array( 'type' => 'string', ), 'EnabledMetrics' => array( 'type' => 'array', 'items' => array( 'name' => 'EnabledMetric', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Metric' => array( 'type' => 'string', ), 'Granularity' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), 'Tags' => array( 'type' => 'array', 'items' => array( 'name' => 'TagDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'PropagateAtLaunch' => array( 'type' => 'boolean', ), ), ), ), 'TerminationPolicies' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlStringMaxLen1600', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'AutoScalingInstancesType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AutoScalingInstances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AutoScalingInstanceDetails', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'AutoScalingGroupName' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'LifecycleState' => array( 'type' => 'string', ), 'HealthStatus' => array( 'type' => 'string', ), 'LaunchConfigurationName' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeAutoScalingNotificationTypesAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AutoScalingNotificationTypes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'LaunchConfigurationsType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LaunchConfigurations' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'LaunchConfiguration', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'LaunchConfigurationName' => array( 'type' => 'string', ), 'LaunchConfigurationARN' => array( 'type' => 'string', ), 'ImageId' => array( 'type' => 'string', ), 'KeyName' => array( 'type' => 'string', ), 'SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'sentAs' => 'member', ), ), 'UserData' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'KernelId' => array( 'type' => 'string', ), 'RamdiskId' => array( 'type' => 'string', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'VolumeType' => array( 'type' => 'string', ), 'DeleteOnTermination' => array( 'type' => 'boolean', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'boolean', ), ), ), ), 'InstanceMonitoring' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), ), ), 'SpotPrice' => array( 'type' => 'string', ), 'IamInstanceProfile' => array( 'type' => 'string', ), 'CreatedTime' => array( 'type' => 'string', ), 'EbsOptimized' => array( 'type' => 'boolean', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeMetricCollectionTypesAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Metrics' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MetricCollectionType', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Metric' => array( 'type' => 'string', ), ), ), ), 'Granularities' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MetricGranularityType', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Granularity' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeNotificationConfigurationsAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NotificationConfigurations' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'NotificationConfiguration', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AutoScalingGroupName' => array( 'type' => 'string', ), 'TopicARN' => array( 'type' => 'string', ), 'NotificationType' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'PoliciesType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ScalingPolicies' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ScalingPolicy', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AutoScalingGroupName' => array( 'type' => 'string', ), 'PolicyName' => array( 'type' => 'string', ), 'ScalingAdjustment' => array( 'type' => 'numeric', ), 'AdjustmentType' => array( 'type' => 'string', ), 'Cooldown' => array( 'type' => 'numeric', ), 'PolicyARN' => array( 'type' => 'string', ), 'Alarms' => array( 'type' => 'array', 'items' => array( 'name' => 'Alarm', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AlarmName' => array( 'type' => 'string', ), 'AlarmARN' => array( 'type' => 'string', ), ), ), ), 'MinAdjustmentStep' => array( 'type' => 'numeric', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ActivitiesType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Activities' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Activity', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ActivityId' => array( 'type' => 'string', ), 'AutoScalingGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Cause' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'EndTime' => array( 'type' => 'string', ), 'StatusCode' => array( 'type' => 'string', ), 'StatusMessage' => array( 'type' => 'string', ), 'Progress' => array( 'type' => 'numeric', ), 'Details' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ProcessesType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Processes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ProcessType', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ProcessName' => array( 'type' => 'string', ), ), ), ), ), ), 'ScheduledActionsType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ScheduledUpdateGroupActions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ScheduledUpdateGroupAction', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AutoScalingGroupName' => array( 'type' => 'string', ), 'ScheduledActionName' => array( 'type' => 'string', ), 'ScheduledActionARN' => array( 'type' => 'string', ), 'Time' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'EndTime' => array( 'type' => 'string', ), 'Recurrence' => array( 'type' => 'string', ), 'MinSize' => array( 'type' => 'numeric', ), 'MaxSize' => array( 'type' => 'numeric', ), 'DesiredCapacity' => array( 'type' => 'numeric', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'TagsType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Tags' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'TagDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'PropagateAtLaunch' => array( 'type' => 'boolean', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeTerminationPolicyTypesAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TerminationPolicyTypes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'XmlStringMaxLen1600', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'PolicyARNType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyARN' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ActivityType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Activity' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'ActivityId' => array( 'type' => 'string', ), 'AutoScalingGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Cause' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'EndTime' => array( 'type' => 'string', ), 'StatusCode' => array( 'type' => 'string', ), 'StatusMessage' => array( 'type' => 'string', ), 'Progress' => array( 'type' => 'numeric', ), 'Details' => array( 'type' => 'string', ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeAutoScalingGroups' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'AutoScalingGroups', ), 'DescribeAutoScalingInstances' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'AutoScalingInstances', ), 'DescribeLaunchConfigurations' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'LaunchConfigurations', ), 'DescribeNotificationConfigurations' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'NotificationConfigurations', ), 'DescribePolicies' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'ScalingPolicies', ), 'DescribeScalingActivities' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'Activities', ), 'DescribeScheduledActions' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'ScheduledUpdateGroupActions', ), 'DescribeTags' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'Tags', ), ), ), ); sdk-2.5.2/Aws/CloudFormation/CloudFormationClient.php000064411532700161006750000000772312272324172017673 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudformation-%s.php' )) ->build(); } } sdk-2.5.2/Aws/CloudFormation/Enum/Capability.php000064411532700161006750000000141212272324172016561 0ustar '2010-05-15', 'endpointPrefix' => 'cloudformation', 'serviceFullName' => 'AWS CloudFormation', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'CloudFormation', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'CancelUpdateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelUpdateStack', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateStackOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateStack', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TemplateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), 'TemplateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), 'DisableRollback' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'TimeoutInMinutes' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, ), 'NotificationARNs' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NotificationARNs.member', 'maxItems' => 5, 'items' => array( 'name' => 'NotificationARN', 'type' => 'string', ), ), 'Capabilities' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Capabilities.member', 'items' => array( 'name' => 'Capability', 'type' => 'string', ), ), 'OnFailure' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StackPolicyBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'StackPolicyURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1350, ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Quota for the resource has already been reached.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Resource with the name requested already exists.', 'class' => 'AlreadyExistsException', ), array( 'reason' => 'The template contains resources with capabilities that were not specified in the Capabilities parameter.', 'class' => 'InsufficientCapabilitiesException', ), ), ), 'DeleteStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteStack', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeStackEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStackEventsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStackEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), ), ), 'DescribeStackResource' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStackResourceOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStackResource', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LogicalResourceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeStackResources' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStackResourcesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStackResources', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LogicalResourceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PhysicalResourceId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeStacks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStacksOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStacks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), ), ), 'EstimateTemplateCost' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EstimateTemplateCostOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EstimateTemplateCost', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'TemplateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), 'TemplateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), ), ), 'GetStackPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetStackPolicyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetStackPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetTemplateOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ListStackResources' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListStackResourcesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListStackResources', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), ), ), 'ListStacks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListStacksOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListStacks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'StackStatusFilter' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'StackStatusFilter.member', 'items' => array( 'name' => 'StackStatus', 'type' => 'string', ), ), ), ), 'SetStackPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetStackPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'StackPolicyBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'StackPolicyURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1350, ), ), ), 'UpdateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateStackOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateStack', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TemplateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), 'TemplateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'StackPolicyDuringUpdateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'StackPolicyDuringUpdateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1350, ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), 'Capabilities' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Capabilities.member', 'items' => array( 'name' => 'Capability', 'type' => 'string', ), ), 'StackPolicyBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'StackPolicyURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1350, ), ), 'errorResponses' => array( array( 'reason' => 'The template contains resources with capabilities that were not specified in the Capabilities parameter.', 'class' => 'InsufficientCapabilitiesException', ), ), ), 'ValidateTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ValidateTemplateOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ValidateTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'TemplateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), 'TemplateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreateStackOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeStackEventsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackEvents' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StackEvent', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'EventId' => array( 'type' => 'string', ), 'StackName' => array( 'type' => 'string', ), 'LogicalResourceId' => array( 'type' => 'string', ), 'PhysicalResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Timestamp' => array( 'type' => 'string', ), 'ResourceStatus' => array( 'type' => 'string', ), 'ResourceStatusReason' => array( 'type' => 'string', ), 'ResourceProperties' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeStackResourceOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackResourceDetail' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'StackName' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'LogicalResourceId' => array( 'type' => 'string', ), 'PhysicalResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'LastUpdatedTimestamp' => array( 'type' => 'string', ), 'ResourceStatus' => array( 'type' => 'string', ), 'ResourceStatusReason' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Metadata' => array( 'type' => 'string', ), ), ), ), ), 'DescribeStackResourcesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackResources' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StackResource', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'StackName' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'LogicalResourceId' => array( 'type' => 'string', ), 'PhysicalResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Timestamp' => array( 'type' => 'string', ), 'ResourceStatus' => array( 'type' => 'string', ), 'ResourceStatusReason' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeStacksOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stacks' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Stack', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'StackName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Parameters' => array( 'type' => 'array', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), 'CreationTime' => array( 'type' => 'string', ), 'LastUpdatedTime' => array( 'type' => 'string', ), 'StackStatus' => array( 'type' => 'string', ), 'StackStatusReason' => array( 'type' => 'string', ), 'DisableRollback' => array( 'type' => 'boolean', ), 'NotificationARNs' => array( 'type' => 'array', 'items' => array( 'name' => 'NotificationARN', 'type' => 'string', 'sentAs' => 'member', ), ), 'TimeoutInMinutes' => array( 'type' => 'numeric', ), 'Capabilities' => array( 'type' => 'array', 'items' => array( 'name' => 'Capability', 'type' => 'string', 'sentAs' => 'member', ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'Output', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'OutputKey' => array( 'type' => 'string', ), 'OutputValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), 'Tags' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'EstimateTemplateCostOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Url' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetStackPolicyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackPolicyBody' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetTemplateOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TemplateBody' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListStackResourcesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackResourceSummaries' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StackResourceSummary', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'LogicalResourceId' => array( 'type' => 'string', ), 'PhysicalResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'LastUpdatedTimestamp' => array( 'type' => 'string', ), 'ResourceStatus' => array( 'type' => 'string', ), 'ResourceStatusReason' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListStacksOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackSummaries' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StackSummary', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'StackName' => array( 'type' => 'string', ), 'TemplateDescription' => array( 'type' => 'string', ), 'CreationTime' => array( 'type' => 'string', ), 'LastUpdatedTime' => array( 'type' => 'string', ), 'DeletionTime' => array( 'type' => 'string', ), 'StackStatus' => array( 'type' => 'string', ), 'StackStatusReason' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'UpdateStackOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ValidateTemplateOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Parameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'TemplateParameter', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'NoEcho' => array( 'type' => 'boolean', ), 'Description' => array( 'type' => 'string', ), ), ), ), 'Description' => array( 'type' => 'string', 'location' => 'xml', ), 'Capabilities' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Capability', 'type' => 'string', 'sentAs' => 'member', ), ), 'CapabilitiesReason' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeStackEvents' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'StackEvents', ), 'DescribeStacks' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Stacks', ), 'ListStackResources' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'StackResourceSummaries', ), 'ListStacks' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'StackSummaries', ), ), ), ); sdk-2.5.2/Aws/CloudFront/CloudFrontClient.php000064411532700161006750000003034112272324172016147 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudfront-%s.php', )) ->setExceptionParser(new DefaultXmlExceptionParser()) ->setIteratorsConfig(array( 'token_param' => 'Marker', 'token_key' => 'NextMarker', 'more_key' => 'IsTruncated', 'result_key' => 'Items', 'operations' => array( 'ListCloudFrontOriginAccessIdentities', 'ListDistributions', 'ListInvalidations', 'ListStreamingDistributions' ) )) ->build(); } /** * Create a signed URL. Keep in mind that URLs meant for use in media/flash players may have different requirements * for URL formats (e.g. some require that the extension be removed, some require the file name to be prefixed - * mp4:, some require you to add "/cfx/st" into your URL). See * http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/WorkingWithStreamingDistributions.html for * additional details and help. * * This method accepts an array of configuration options: * - url: (string) URL of the resource being signed (can include query string and wildcards). For example: * rtmp://s5c39gqb8ow64r.cloudfront.net/videos/mp3_name.mp3 * http://d111111abcdef8.cloudfront.net/images/horizon.jpg?size=large&license=yes * - policy: (string) JSON policy. Use this option when creating a signed URL for a custom policy. * - expires: (int) UTC Unix timestamp used when signing with a canned policy. Not required when passing a * custom 'policy' option. * - key_pair_id: (string) The ID of the key pair used to sign CloudFront URLs for private distributions. * - private_key: (string) The filepath ot the private key used to sign CloudFront URLs for private distributions. * * @param array $options Array of configuration options used when signing * * @return string The file URL with authentication parameters * @throws InvalidArgumentException if key_pair_id and private_key have not been configured on the client * @throws RequiredExtensionNotLoadedException if the openssl extension is not installed * @link http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/WorkingWithStreamingDistributions.html */ public function getSignedUrl(array $options) { if (!extension_loaded('openssl')) { //@codeCoverageIgnoreStart throw new RequiredExtensionNotLoadedException('The openssl extension is required to sign CloudFront urls.'); //@codeCoverageIgnoreEnd } // Initialize the configuration data and ensure that the url was specified $options = Collection::fromConfig($options, array_filter(array( 'key_pair_id' => $this->getConfig('key_pair_id'), 'private_key' => $this->getConfig('private_key'), )), array('url', 'key_pair_id', 'private_key')); // Determine the scheme of the url $urlSections = explode('://', $options['url']); if (count($urlSections) < 2) { throw new InvalidArgumentException('Invalid URL: ' . $options['url']); } // Get the real scheme by removing wildcards from the scheme $scheme = str_replace('*', '', $urlSections[0]); $policy = $options['policy'] ?: $this->createCannedPolicy($scheme, $options['url'], $options['expires']); // Strip whitespace from the policy $policy = str_replace(' ', '', $policy); $url = Url::factory($scheme . '://' . $urlSections[1]); if ($options['policy']) { // Custom policies require that the encoded policy be specified in the URL $url->getQuery()->set('Policy', strtr(base64_encode($policy), '+=/', '-_~')); } else { // Canned policies require that the Expires parameter be set in the URL $url->getQuery()->set('Expires', $options['expires']); } // Sign the policy using the CloudFront private key $signedPolicy = $this->rsaSha1Sign($policy, $options['private_key']); // Remove whitespace, base64 encode the policy, and replace special characters $signedPolicy = strtr(base64_encode($signedPolicy), '+=/', '-_~'); $url->getQuery() ->set('Signature', $signedPolicy) ->set('Key-Pair-Id', $options['key_pair_id']); if ($scheme != 'rtmp') { // HTTP and HTTPS signed URLs include the full URL return (string) $url; } else { // Use a relative URL when creating Flash player URLs $url->getQuery()->useUrlEncoding(false); $url->setScheme(null)->setHost(null); return substr($url, 1); } } /** * Sign a policy string using OpenSSL RSA SHA1 * * @param string $policy Policy to sign * @param string $privateKeyFilename File containing the OpenSSL private key * * @return string */ protected function rsaSha1Sign($policy, $privateKeyFilename) { $signature = ''; openssl_sign($policy, $signature, file_get_contents($privateKeyFilename)); return $signature; } /** * Create a canned policy for a particular URL and expiration * * @param string $scheme Parsed scheme without wildcards * @param string $url URL that is being signed * @param int $expires Time in which the signature expires * * @return string * @throws InvalidArgumentException if the expiration is not set */ protected function createCannedPolicy($scheme, $url, $expires) { if (!$expires) { throw new InvalidArgumentException('An expires option is required when using a canned policy'); } // Generate a canned policy if ($scheme == 'http' || $scheme == 'https') { $resource = $url; } elseif ($scheme == 'rtmp') { $parts = parse_url($url); $pathParts = pathinfo($parts['path']); // Add path leading to file, strip file extension, and add a query string if present $resource = ltrim($pathParts['dirname'] . '/' . $pathParts['basename'], '/') . (isset($parts['query']) ? "?{$parts['query']}" : ''); } else { throw new InvalidArgumentException("Invalid URI scheme: {$scheme}. Must be one of http or rtmp."); } return sprintf( '{"Statement":[{"Resource":"%s","Condition":{"DateLessThan":{"AWS:EpochTime":%d}}}]}', $resource, $expires ); } } sdk-2.5.2/Aws/CloudFront/CloudFrontSignature.php000064411532700161006750000000421112272324172016667 0ustar hasHeader('date') && !$request->hasHeader('x-amz-date')) { $request->setHeader('Date', gmdate(DateFormat::RFC2822)); } $stringToSign = (string) $request->getHeader('Date') ?: (string) $request->getHeader('x-amz-date'); $request->getParams()->set('aws.string_to_sign', $stringToSign); $request->setHeader( 'Authorization', 'AWS ' . $credentials->getAccessKeyId() . ':' . $this->signString($stringToSign, $credentials) ); } /** * Sign a signature string by applying SHA-1 HMAC hashing. * * @param string $string The signature string to hash. * @param CredentialsInterface $credentials Signing credentials. * * @return string The hashed signature string. */ public function signString($string, CredentialsInterface $credentials) { return base64_encode(hash_hmac('sha1', $string, $credentials->getSecretKey(), true)); } } sdk-2.5.2/Aws/CloudFront/Enum/GeoRestrictionType.php000064411532700161006750000000151012272324172017433 0ustar '2012-05-05', 'endpointPrefix' => 'cloudfront', 'serviceFullName' => 'Amazon CloudFront', 'serviceAbbreviation' => 'CloudFront', 'serviceType' => 'rest-xml', 'globalEndpoint' => 'cloudfront.amazonaws.com', 'signatureVersion' => 'cloudfront', 'namespace' => 'CloudFront', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), ), 'operations' => array( 'CreateCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/2012-05-05/origin-access-identity/cloudfront', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'summary' => 'Create a new origin access identity.', 'data' => array( 'xmlRoot' => array( 'name' => 'CloudFrontOriginAccessIdentityConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CloudFrontOriginAccessIdentityAlreadyExistsException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'TooManyCloudFrontOriginAccessIdentitiesException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateDistribution' => array( 'httpMethod' => 'POST', 'uri' => '/2012-05-05/distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateDistributionResult', 'responseType' => 'model', 'summary' => 'Create a new distribution.', 'data' => array( 'xmlRoot' => array( 'name' => 'DistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'required' => true, 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'DefaultRootObject' => array( 'required' => true, 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'required' => true, 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'required' => true, 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'required' => true, 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'required' => true, 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'required' => true, 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'required' => true, 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', 'enum' => array( 'http-only', 'match-viewer', ), ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'required' => true, 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'required' => true, 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', 'enum' => array( 'allow-all', 'https-only', ), ), 'MinTTL' => array( 'required' => true, 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'required' => true, 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'PathPattern' => array( 'required' => true, 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'required' => true, 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', 'enum' => array( 'allow-all', 'https-only', ), ), 'MinTTL' => array( 'required' => true, 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'required' => true, 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'DistributionAlreadyExistsException', ), array( 'class' => 'InvalidOriginException', ), array( 'class' => 'InvalidOriginAccessIdentityException', ), array( 'class' => 'AccessDeniedException', ), array( 'class' => 'TooManyTrustedSignersException', ), array( 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'TooManyDistributionCNAMEsException', ), array( 'class' => 'TooManyDistributionsException', ), array( 'class' => 'InvalidDefaultRootObjectException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InvalidRequiredProtocolException', ), array( 'class' => 'NoSuchOriginException', ), array( 'class' => 'TooManyOriginsException', ), array( 'class' => 'TooManyCacheBehaviorsException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateInvalidation' => array( 'httpMethod' => 'POST', 'uri' => '/2012-05-05/distribution/{DistributionId}/invalidation', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateInvalidationResult', 'responseType' => 'model', 'summary' => 'Create a new invalidation.', 'data' => array( 'xmlRoot' => array( 'name' => 'InvalidationBatch', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'DistributionId' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'Paths' => array( 'required' => true, 'description' => 'The path of the object to invalidate. The path is relative to the distribution and must begin with a slash (/). You must enclose each invalidation object with the Path element tags. If the path includes non-ASCII characters or unsafe characters as defined in RFC 1783 (http://www.ietf.org/rfc/rfc1738.txt), URL encode those characters. Do not URL encode any other characters in the path, or CloudFront will not invalidate the old version of the updated object.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of objects that you want to invalidate.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains a list of the objects that you want to invalidate.', 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', ), ), ), ), 'CallerReference' => array( 'required' => true, 'description' => 'A unique name that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the Path object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create an invalidation batch, and the content of each Path element is identical to the original request, the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of any Path is different from the original request, CloudFront returns an InvalidationBatchAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'BatchTooLargeException', ), array( 'class' => 'TooManyInvalidationsInProgressException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateStreamingDistribution' => array( 'httpMethod' => 'POST', 'uri' => '/2012-05-05/streaming-distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateStreamingDistributionResult', 'responseType' => 'model', 'summary' => 'Create a new streaming distribution.', 'data' => array( 'xmlRoot' => array( 'name' => 'StreamingDistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'required' => true, 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'required' => true, 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'required' => true, 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'required' => true, 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'Enabled' => array( 'required' => true, 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'StreamingDistributionAlreadyExistsException', ), array( 'class' => 'InvalidOriginException', ), array( 'class' => 'InvalidOriginAccessIdentityException', ), array( 'class' => 'AccessDeniedException', ), array( 'class' => 'TooManyTrustedSignersException', ), array( 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'TooManyStreamingDistributionCNAMEsException', ), array( 'class' => 'TooManyStreamingDistributionsException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'DeleteCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-05-05/origin-access-identity/cloudfront/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteCloudFrontOriginAccessIdentity2012_05_05Output', 'responseType' => 'model', 'summary' => 'Delete an origin access identity.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The origin access identity\'s id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received from a previous GET or PUT request. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'class' => 'PreconditionFailedException', ), array( 'class' => 'CloudFrontOriginAccessIdentityInUseException', ), ), ), 'DeleteDistribution' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-05-05/distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteDistribution2012_05_05Output', 'responseType' => 'model', 'summary' => 'Delete a distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The distribution id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when you disabled the distribution. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'DistributionNotDisabledException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'PreconditionFailedException', ), ), ), 'DeleteStreamingDistribution' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-05-05/streaming-distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteStreamingDistribution2012_05_05Output', 'responseType' => 'model', 'summary' => 'Delete a streaming distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The distribution id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when you disabled the streaming distribution. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'StreamingDistributionNotDisabledException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'NoSuchStreamingDistributionException', ), array( 'class' => 'PreconditionFailedException', ), ), ), 'GetCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/origin-access-identity/cloudfront/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'summary' => 'Get the information about an origin access identity.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The identity\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetCloudFrontOriginAccessIdentityConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/origin-access-identity/cloudfront/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetCloudFrontOriginAccessIdentityConfigResult', 'responseType' => 'model', 'summary' => 'Get the configuration information about an origin access identity.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The identity\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetDistribution' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetDistributionResult', 'responseType' => 'model', 'summary' => 'Get the information about a distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetDistributionConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetDistributionConfigResult', 'responseType' => 'model', 'summary' => 'Get the configuration information about a distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetInvalidation' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution/{DistributionId}/invalidation/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetInvalidationResult', 'responseType' => 'model', 'summary' => 'Get the information about an invalidation.', 'parameters' => array( 'DistributionId' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'Id' => array( 'required' => true, 'description' => 'The invalidation\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchInvalidationException', ), array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetStreamingDistribution' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/streaming-distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetStreamingDistributionResult', 'responseType' => 'model', 'summary' => 'Get the information about a streaming distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The streaming distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchStreamingDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetStreamingDistributionConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/streaming-distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetStreamingDistributionConfigResult', 'responseType' => 'model', 'summary' => 'Get the configuration information about a streaming distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The streaming distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchStreamingDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'ListCloudFrontOriginAccessIdentities' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/origin-access-identity/cloudfront', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListCloudFrontOriginAccessIdentitiesResult', 'responseType' => 'model', 'summary' => 'List origin access identities.', 'parameters' => array( 'Marker' => array( 'description' => 'Use this when paginating results to indicate where to begin in your list of origin access identities. The results include identities in the list that occur after the marker. To get the next page of results, set the Marker to the value of the NextMarker from the current page\'s response (which is also the ID of the last identity on that page).', 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'description' => 'The maximum number of origin access identities you want in the response body.', 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'InvalidArgumentException', ), ), ), 'ListDistributions' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListDistributionsResult', 'responseType' => 'model', 'summary' => 'List distributions.', 'parameters' => array( 'Marker' => array( 'description' => 'Use this when paginating results to indicate where to begin in your list of distributions. The results include distributions in the list that occur after the marker. To get the next page of results, set the Marker to the value of the NextMarker from the current page\'s response (which is also the ID of the last distribution on that page).', 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'description' => 'The maximum number of distributions you want in the response body.', 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'InvalidArgumentException', ), ), ), 'ListInvalidations' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution/{DistributionId}/invalidation', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListInvalidationsResult', 'responseType' => 'model', 'summary' => 'List invalidation batches.', 'parameters' => array( 'DistributionId' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'Marker' => array( 'description' => 'Use this parameter when paginating results to indicate where to begin in your list of invalidation batches. Because the results are returned in decreasing order from most recent to oldest, the most recent results are on the first page, the second page will contain earlier results, and so on. To get the next page of results, set the Marker to the value of the NextMarker from the current page\'s response. This value is the same as the ID of the last invalidation batch on that page.', 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'description' => 'The maximum number of invalidation batches you want in the response body.', 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'NoSuchDistributionException', ), ), ), 'ListStreamingDistributions' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/streaming-distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListStreamingDistributionsResult', 'responseType' => 'model', 'summary' => 'List streaming distributions.', 'parameters' => array( 'Marker' => array( 'description' => 'Use this when paginating results to indicate where to begin in your list of streaming distributions. The results include distributions in the list that occur after the marker. To get the next page of results, set the Marker to the value of the NextMarker from the current page\'s response (which is also the ID of the last distribution on that page).', 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'description' => 'The maximum number of streaming distributions you want in the response body.', 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'InvalidArgumentException', ), ), ), 'UpdateCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'PUT', 'uri' => '/2012-05-05/origin-access-identity/cloudfront/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'summary' => 'Update an origin access identity.', 'data' => array( 'xmlRoot' => array( 'name' => 'CloudFrontOriginAccessIdentityConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'description' => 'The identity\'s id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when retrieving the identity\'s configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'IllegalUpdateException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'class' => 'PreconditionFailedException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'UpdateDistribution' => array( 'httpMethod' => 'PUT', 'uri' => '/2012-05-05/distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateDistributionResult', 'responseType' => 'model', 'summary' => 'Update a distribution.', 'data' => array( 'xmlRoot' => array( 'name' => 'DistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'required' => true, 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'DefaultRootObject' => array( 'required' => true, 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'required' => true, 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'required' => true, 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'required' => true, 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'required' => true, 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'required' => true, 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'required' => true, 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', 'enum' => array( 'http-only', 'match-viewer', ), ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'required' => true, 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'required' => true, 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', 'enum' => array( 'allow-all', 'https-only', ), ), 'MinTTL' => array( 'required' => true, 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'required' => true, 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'PathPattern' => array( 'required' => true, 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'required' => true, 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', 'enum' => array( 'allow-all', 'https-only', ), ), 'MinTTL' => array( 'required' => true, 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'required' => true, 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when retrieving the distribution\'s configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'IllegalUpdateException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'PreconditionFailedException', ), array( 'class' => 'TooManyDistributionCNAMEsException', ), array( 'class' => 'InvalidDefaultRootObjectException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InvalidOriginAccessIdentityException', ), array( 'class' => 'TooManyTrustedSignersException', ), array( 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'InvalidRequiredProtocolException', ), array( 'class' => 'NoSuchOriginException', ), array( 'class' => 'TooManyOriginsException', ), array( 'class' => 'TooManyCacheBehaviorsException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'UpdateStreamingDistribution' => array( 'httpMethod' => 'PUT', 'uri' => '/2012-05-05/streaming-distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateStreamingDistributionResult', 'responseType' => 'model', 'summary' => 'Update a streaming distribution.', 'data' => array( 'xmlRoot' => array( 'name' => 'StreamingDistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'required' => true, 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'required' => true, 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'required' => true, 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'required' => true, 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'Enabled' => array( 'required' => true, 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'description' => 'The streaming distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when retrieving the streaming distribution\'s configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'IllegalUpdateException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'NoSuchStreamingDistributionException', ), array( 'class' => 'PreconditionFailedException', ), array( 'class' => 'TooManyStreamingDistributionCNAMEsException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InvalidOriginAccessIdentityException', ), array( 'class' => 'TooManyTrustedSignersException', ), array( 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), ), 'models' => array( 'CreateCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The ID for the origin access identity. For example: E74FTE3AJFJ256A.', 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'description' => 'The Amazon S3 canonical user ID for the origin access identity, which you use when giving the origin access identity read permission to an object in Amazon S3.', 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'description' => 'The current configuration information for the identity.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', ), 'Comment' => array( 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', ), ), ), 'Location' => array( 'description' => 'The fully qualified URI of the new origin access identity just created. For example: https://cloudfront.amazonaws.com/2010-11-01/origin-access-identity/cloudfront/E74FTE3AJFJ256A.', 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'description' => 'The current version of the origin access identity created.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'This response element indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'description' => 'The number of invalidation batches currently in progress.', 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'description' => 'The current configuration information for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'Location' => array( 'description' => 'The fully qualified URI of the new distribution resource just created. For example: https://cloudfront.amazonaws.com/2010-11-01/distribution/EDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'description' => 'The current version of the distribution created.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateInvalidationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Location' => array( 'description' => 'The fully qualified URI of the distribution and invalidation batch request, including the Invalidation ID.', 'type' => 'string', 'location' => 'header', ), 'Id' => array( 'description' => 'The identifier for the invalidation request. For example: IDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The status of the invalidation request. When the invalidation batch is finished, the status is Completed.', 'type' => 'string', 'location' => 'xml', ), 'CreateTime' => array( 'description' => 'The date and time the invalidation request was first made.', 'type' => 'string', 'location' => 'xml', ), 'InvalidationBatch' => array( 'description' => 'The current invalidation information for the batch request.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Paths' => array( 'description' => 'The path of the object to invalidate. The path is relative to the distribution and must begin with a slash (/). You must enclose each invalidation object with the Path element tags. If the path includes non-ASCII characters or unsafe characters as defined in RFC 1783 (http://www.ietf.org/rfc/rfc1738.txt), URL encode those characters. Do not URL encode any other characters in the path, or CloudFront will not invalidate the old version of the updated object.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of objects that you want to invalidate.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains a list of the objects that you want to invalidate.', 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', 'sentAs' => 'Path', ), ), ), ), 'CallerReference' => array( 'description' => 'A unique name that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the Path object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create an invalidation batch, and the content of each Path element is identical to the original request, the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of any Path is different from the original request, CloudFront returns an InvalidationBatchAlreadyExists error.', 'type' => 'string', ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the streaming distribution. For example: EGTXBD79H29TRA8.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The current status of the streaming distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the streaming distribution. For example: s5c39gqb8ow64r.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'description' => 'The current configuration information for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Enabled' => array( 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'Location' => array( 'description' => 'The fully qualified URI of the new streaming distribution resource just created. For example: https://cloudfront.amazonaws.com/2010-11-01/streaming-distribution/EGTXBD79H29TRA8.', 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'description' => 'The current version of the streaming distribution created.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteCloudFrontOriginAccessIdentity2012_05_05Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteDistribution2012_05_05Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteStreamingDistribution2012_05_05Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The ID for the origin access identity. For example: E74FTE3AJFJ256A.', 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'description' => 'The Amazon S3 canonical user ID for the origin access identity, which you use when giving the origin access identity read permission to an object in Amazon S3.', 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'description' => 'The current configuration information for the identity.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', ), 'Comment' => array( 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', ), ), ), 'ETag' => array( 'description' => 'The current version of the origin access identity\'s information. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetCloudFrontOriginAccessIdentityConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', 'location' => 'xml', ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'This response element indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'description' => 'The number of invalidation batches currently in progress.', 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'description' => 'The current configuration information for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'ETag' => array( 'description' => 'The current version of the distribution\'s information. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetDistributionConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'location' => 'xml', ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetInvalidationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the invalidation request. For example: IDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The status of the invalidation request. When the invalidation batch is finished, the status is Completed.', 'type' => 'string', 'location' => 'xml', ), 'CreateTime' => array( 'description' => 'The date and time the invalidation request was first made.', 'type' => 'string', 'location' => 'xml', ), 'InvalidationBatch' => array( 'description' => 'The current invalidation information for the batch request.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Paths' => array( 'description' => 'The path of the object to invalidate. The path is relative to the distribution and must begin with a slash (/). You must enclose each invalidation object with the Path element tags. If the path includes non-ASCII characters or unsafe characters as defined in RFC 1783 (http://www.ietf.org/rfc/rfc1738.txt), URL encode those characters. Do not URL encode any other characters in the path, or CloudFront will not invalidate the old version of the updated object.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of objects that you want to invalidate.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains a list of the objects that you want to invalidate.', 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', 'sentAs' => 'Path', ), ), ), ), 'CallerReference' => array( 'description' => 'A unique name that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the Path object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create an invalidation batch, and the content of each Path element is identical to the original request, the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of any Path is different from the original request, CloudFront returns an InvalidationBatchAlreadyExists error.', 'type' => 'string', ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the streaming distribution. For example: EGTXBD79H29TRA8.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The current status of the streaming distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the streaming distribution. For example: s5c39gqb8ow64r.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'description' => 'The current configuration information for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Enabled' => array( 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'ETag' => array( 'description' => 'The current version of the streaming distribution\'s information. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetStreamingDistributionConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Enabled' => array( 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'location' => 'xml', ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListCloudFrontOriginAccessIdentitiesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'description' => 'The value you provided for the Marker request parameter.', 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'description' => 'If IsTruncated is true, this element is present and contains the value you can use for the Marker request parameter to continue listing your origin access identities where they left off.', 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'description' => 'The value you provided for the MaxItems request parameter.', 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'description' => 'A flag that indicates whether more origin access identities remain to be listed. If your results were truncated, you can make a follow-up pagination request using the Marker request parameter to retrieve more items in the list.', 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'description' => 'The number of CloudFront origin access identities that were created by the current AWS account.', 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'description' => 'A complex type that contains one CloudFrontOriginAccessIdentitySummary element for each origin access identity that was created by the current AWS account.', 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CloudFrontOriginAccessIdentitySummary', 'description' => 'Summary of the information about a CloudFront origin access identity.', 'type' => 'object', 'sentAs' => 'CloudFrontOriginAccessIdentitySummary', 'properties' => array( 'Id' => array( 'description' => 'The ID for the origin access identity. For example: E74FTE3AJFJ256A.', 'type' => 'string', ), 'S3CanonicalUserId' => array( 'description' => 'The Amazon S3 canonical user ID for the origin access identity, which you use when giving the origin access identity read permission to an object in Amazon S3.', 'type' => 'string', ), 'Comment' => array( 'description' => 'The comment for this origin access identity, as originally specified when created.', 'type' => 'string', ), ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListDistributionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'description' => 'The value you provided for the Marker request parameter.', 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'description' => 'If IsTruncated is true, this element is present and contains the value you can use for the Marker request parameter to continue listing your distributions where they left off.', 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'description' => 'The value you provided for the MaxItems request parameter.', 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'description' => 'A flag that indicates whether more distributions remain to be listed. If your results were truncated, you can make a follow-up pagination request using the Marker request parameter to retrieve more distributions in the list.', 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'description' => 'The number of distributions that were created by the current AWS account.', 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'description' => 'A complex type that contains one DistributionSummary element for each distribution that was created by the current AWS account.', 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DistributionSummary', 'description' => 'A summary of the information for an Amazon CloudFront distribution.', 'type' => 'object', 'sentAs' => 'DistributionSummary', 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', ), 'Status' => array( 'description' => 'This response element indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'The comment originally specified when this distribution was created.', 'type' => 'string', ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListInvalidationsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'description' => 'The value you provided for the Marker request parameter.', 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'description' => 'If IsTruncated is true, this element is present and contains the value you can use for the Marker request parameter to continue listing your invalidation batches where they left off.', 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'description' => 'The value you provided for the MaxItems request parameter.', 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'description' => 'A flag that indicates whether more invalidation batch requests remain to be listed. If your results were truncated, you can make a follow-up pagination request using the Marker request parameter to retrieve more invalidation batches in the list.', 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'description' => 'The number of invalidation batches that were created by the current AWS account.', 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'description' => 'A complex type that contains one InvalidationSummary element for each invalidation batch that was created by the current AWS account.', 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InvalidationSummary', 'description' => 'Summary of an invalidation request.', 'type' => 'object', 'sentAs' => 'InvalidationSummary', 'properties' => array( 'Id' => array( 'description' => 'The unique ID for an invalidation request.', 'type' => 'string', ), 'Status' => array( 'description' => 'The status of an invalidation request.', 'type' => 'string', ), ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListStreamingDistributionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'description' => 'The value you provided for the Marker request parameter.', 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'description' => 'If IsTruncated is true, this element is present and contains the value you can use for the Marker request parameter to continue listing your streaming distributions where they left off.', 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'description' => 'The value you provided for the MaxItems request parameter.', 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'description' => 'A flag that indicates whether more streaming distributions remain to be listed. If your results were truncated, you can make a follow-up pagination request using the Marker request parameter to retrieve more distributions in the list.', 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'description' => 'The number of streaming distributions that were created by the current AWS account.', 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'description' => 'A complex type that contains one StreamingDistributionSummary element for each distribution that was created by the current AWS account.', 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StreamingDistributionSummary', 'description' => 'A summary of the information for an Amazon CloudFront streaming distribution.', 'type' => 'object', 'sentAs' => 'StreamingDistributionSummary', 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', ), 'Status' => array( 'description' => 'Indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Comment' => array( 'description' => 'The comment originally specified when this distribution was created.', 'type' => 'string', ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The ID for the origin access identity. For example: E74FTE3AJFJ256A.', 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'description' => 'The Amazon S3 canonical user ID for the origin access identity, which you use when giving the origin access identity read permission to an object in Amazon S3.', 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'description' => 'The current configuration information for the identity.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', ), 'Comment' => array( 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', ), ), ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'This response element indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'description' => 'The number of invalidation batches currently in progress.', 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'description' => 'The current configuration information for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the streaming distribution. For example: EGTXBD79H29TRA8.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The current status of the streaming distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the streaming distribution. For example: s5c39gqb8ow64r.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'description' => 'The current configuration information for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Enabled' => array( 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), ), 'waiters' => array( '__default__' => array( 'success.type' => 'output', 'success.path' => 'Status', ), 'StreamingDistributionDeployed' => array( 'operation' => 'GetStreamingDistribution', 'description' => 'Wait until a streaming distribution is deployed.', 'interval' => 60, 'max_attempts' => 25, 'success.value' => 'Deployed', ), 'DistributionDeployed' => array( 'operation' => 'GetDistribution', 'description' => 'Wait until a distribution is deployed.', 'interval' => 60, 'max_attempts' => 25, 'success.value' => 'Deployed', ), 'InvalidationCompleted' => array( 'operation' => 'GetInvalidation', 'description' => 'Wait until an invalidation has completed.', 'interval' => 20, 'max_attempts' => 30, 'success.value' => 'Completed', ), ), ); sdk-2.5.2/Aws/CloudFront/Resources/cloudfront-2013-11-11.php000064411532700161006750000074067412272324172020124 0ustar '2013-11-11', 'endpointPrefix' => 'cloudfront', 'serviceFullName' => 'Amazon CloudFront', 'serviceAbbreviation' => 'CloudFront', 'serviceType' => 'rest-xml', 'globalEndpoint' => 'cloudfront.amazonaws.com', 'signatureVersion' => 'v4', 'namespace' => 'CloudFront', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), ), 'operations' => array( 'CreateCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/2013-11-11/origin-access-identity/cloudfront', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'CloudFrontOriginAccessIdentityConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'class' => 'CloudFrontOriginAccessIdentityAlreadyExistsException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'Processing your request would cause you to exceed the maximum number of origin access identities allowed.', 'class' => 'TooManyCloudFrontOriginAccessIdentitiesException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateDistribution' => array( 'httpMethod' => 'POST', 'uri' => '/2013-11-11/distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateDistributionResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'DistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'DefaultRootObject' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Origin', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'DomainName' => array( 'required' => true, 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'required' => true, 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'required' => true, 'type' => 'numeric', ), 'HTTPSPort' => array( 'required' => true, 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'required' => true, 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Cookies' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Forward' => array( 'required' => true, 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), 'MinTTL' => array( 'required' => true, 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', ), ), ), ), ), ), 'CacheBehaviors' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'properties' => array( 'PathPattern' => array( 'required' => true, 'type' => 'string', ), 'TargetOriginId' => array( 'required' => true, 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Cookies' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Forward' => array( 'required' => true, 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), 'MinTTL' => array( 'required' => true, 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'properties' => array( 'ErrorCode' => array( 'required' => true, 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'IncludeCookies' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), ), ), 'PriceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'ViewerCertificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'Restrictions' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'GeoRestriction' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'required' => true, 'type' => 'string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', ), ), ), ), ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'reason' => 'The caller reference you attempted to create the distribution with is associated with another distribution.', 'class' => 'DistributionAlreadyExistsException', ), array( 'reason' => 'The Amazon S3 origin server specified does not refer to a valid Amazon S3 bucket.', 'class' => 'InvalidOriginException', ), array( 'reason' => 'The origin access identity is not valid or doesn\'t exist.', 'class' => 'InvalidOriginAccessIdentityException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Your request contains more trusted signers than are allowed per distribution.', 'class' => 'TooManyTrustedSignersException', ), array( 'reason' => 'One or more of your trusted signers do not exist.', 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'InvalidViewerCertificateException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'Your request contains more CNAMEs than are allowed per distribution.', 'class' => 'TooManyDistributionCNAMEsException', ), array( 'reason' => 'Processing your request would cause you to exceed the maximum number of distributions allowed.', 'class' => 'TooManyDistributionsException', ), array( 'reason' => 'The default root object file name is too big or contains an invalid character.', 'class' => 'InvalidDefaultRootObjectException', ), array( 'reason' => 'The relative path is too big, is not URL-encoded, or does not begin with a slash (/).', 'class' => 'InvalidRelativePathException', ), array( 'class' => 'InvalidErrorCodeException', ), array( 'class' => 'InvalidResponseCodeException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'This operation requires the HTTPS protocol. Ensure that you specify the HTTPS protocol in your request, or omit the RequiredProtocols element from your distribution configuration.', 'class' => 'InvalidRequiredProtocolException', ), array( 'reason' => 'No origin exists with the specified Origin Id.', 'class' => 'NoSuchOriginException', ), array( 'reason' => 'You cannot create anymore origins for the distribution.', 'class' => 'TooManyOriginsException', ), array( 'reason' => 'You cannot create anymore cache behaviors for the distribution.', 'class' => 'TooManyCacheBehaviorsException', ), array( 'reason' => 'Your request contains more cookie names in the whitelist than are allowed per cache behavior.', 'class' => 'TooManyCookieNamesInWhiteListException', ), array( 'reason' => 'Your request contains forward cookies option which doesn\'t match with the expectation for the whitelisted list of cookie names. Either list of cookie names has been specified when not allowed or list of cookie names is missing when expected.', 'class' => 'InvalidForwardCookiesException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), array( 'reason' => 'You cannot create anymore custom ssl certificates.', 'class' => 'TooManyCertificatesException', ), array( 'class' => 'InvalidLocationCodeException', ), array( 'class' => 'InvalidGeoRestrictionParameterException', ), ), ), 'CreateInvalidation' => array( 'httpMethod' => 'POST', 'uri' => '/2013-11-11/distribution/{DistributionId}/invalidation', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateInvalidationResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'InvalidationBatch', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'DistributionId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Paths' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', ), ), ), ), 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'class' => 'BatchTooLargeException', ), array( 'reason' => 'You have exceeded the maximum number of allowable InProgress invalidation batch requests, or invalidation objects.', 'class' => 'TooManyInvalidationsInProgressException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateStreamingDistribution' => array( 'httpMethod' => 'POST', 'uri' => '/2013-11-11/streaming-distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateStreamingDistributionResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'StreamingDistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'required' => true, 'type' => 'string', ), 'OriginAccessIdentity' => array( 'required' => true, 'type' => 'string', ), ), ), 'Aliases' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'PriceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'StreamingDistributionAlreadyExistsException', ), array( 'reason' => 'The Amazon S3 origin server specified does not refer to a valid Amazon S3 bucket.', 'class' => 'InvalidOriginException', ), array( 'reason' => 'The origin access identity is not valid or doesn\'t exist.', 'class' => 'InvalidOriginAccessIdentityException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Your request contains more trusted signers than are allowed per distribution.', 'class' => 'TooManyTrustedSignersException', ), array( 'reason' => 'One or more of your trusted signers do not exist.', 'class' => 'TrustedSignerDoesNotExistException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'class' => 'TooManyStreamingDistributionCNAMEsException', ), array( 'reason' => 'Processing your request would cause you to exceed the maximum number of streaming distributions allowed.', 'class' => 'TooManyStreamingDistributionsException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), 'DeleteCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'DELETE', 'uri' => '/2013-11-11/origin-access-identity/cloudfront/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteCloudFrontOriginAccessIdentity2013_11_11Output', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'The specified origin access identity does not exist.', 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), array( 'class' => 'CloudFrontOriginAccessIdentityInUseException', ), ), ), 'DeleteDistribution' => array( 'httpMethod' => 'DELETE', 'uri' => '/2013-11-11/distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteDistribution2013_11_11Output', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'class' => 'DistributionNotDisabledException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), ), ), 'DeleteStreamingDistribution' => array( 'httpMethod' => 'DELETE', 'uri' => '/2013-11-11/streaming-distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteStreamingDistribution2013_11_11Output', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'class' => 'StreamingDistributionNotDisabledException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'The specified streaming distribution does not exist.', 'class' => 'NoSuchStreamingDistributionException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), ), ), 'GetCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/origin-access-identity/cloudfront/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified origin access identity does not exist.', 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetCloudFrontOriginAccessIdentityConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/origin-access-identity/cloudfront/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetCloudFrontOriginAccessIdentityConfigResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified origin access identity does not exist.', 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetDistribution' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetDistributionResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetDistributionConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetDistributionConfigResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetInvalidation' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution/{DistributionId}/invalidation/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetInvalidationResult', 'responseType' => 'model', 'parameters' => array( 'DistributionId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified invalidation does not exist.', 'class' => 'NoSuchInvalidationException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetStreamingDistribution' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/streaming-distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetStreamingDistributionResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified streaming distribution does not exist.', 'class' => 'NoSuchStreamingDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetStreamingDistributionConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/streaming-distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetStreamingDistributionConfigResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified streaming distribution does not exist.', 'class' => 'NoSuchStreamingDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'ListCloudFrontOriginAccessIdentities' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/origin-access-identity/cloudfront', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListCloudFrontOriginAccessIdentitiesResult', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), ), ), 'ListDistributions' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListDistributionsResult', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), ), ), 'ListInvalidations' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution/{DistributionId}/invalidation', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListInvalidationsResult', 'responseType' => 'model', 'parameters' => array( 'DistributionId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Marker' => array( 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'ListStreamingDistributions' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/streaming-distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListStreamingDistributionsResult', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), ), ), 'UpdateCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'PUT', 'uri' => '/2013-11-11/origin-access-identity/cloudfront/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'CloudFrontOriginAccessIdentityConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Origin and CallerReference cannot be updated.', 'class' => 'IllegalUpdateException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'The specified origin access identity does not exist.', 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), 'UpdateDistribution' => array( 'httpMethod' => 'PUT', 'uri' => '/2013-11-11/distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateDistributionResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'DistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'DefaultRootObject' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Origin', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'DomainName' => array( 'required' => true, 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'required' => true, 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'required' => true, 'type' => 'numeric', ), 'HTTPSPort' => array( 'required' => true, 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'required' => true, 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Cookies' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Forward' => array( 'required' => true, 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), 'MinTTL' => array( 'required' => true, 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', ), ), ), ), ), ), 'CacheBehaviors' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'properties' => array( 'PathPattern' => array( 'required' => true, 'type' => 'string', ), 'TargetOriginId' => array( 'required' => true, 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Cookies' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Forward' => array( 'required' => true, 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), 'MinTTL' => array( 'required' => true, 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'properties' => array( 'ErrorCode' => array( 'required' => true, 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'IncludeCookies' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), ), ), 'PriceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'ViewerCertificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'Restrictions' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'GeoRestriction' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'required' => true, 'type' => 'string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', ), ), ), ), ), ), 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'reason' => 'Origin and CallerReference cannot be updated.', 'class' => 'IllegalUpdateException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), array( 'reason' => 'Your request contains more CNAMEs than are allowed per distribution.', 'class' => 'TooManyDistributionCNAMEsException', ), array( 'reason' => 'The default root object file name is too big or contains an invalid character.', 'class' => 'InvalidDefaultRootObjectException', ), array( 'reason' => 'The relative path is too big, is not URL-encoded, or does not begin with a slash (/).', 'class' => 'InvalidRelativePathException', ), array( 'class' => 'InvalidErrorCodeException', ), array( 'class' => 'InvalidResponseCodeException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The origin access identity is not valid or doesn\'t exist.', 'class' => 'InvalidOriginAccessIdentityException', ), array( 'reason' => 'Your request contains more trusted signers than are allowed per distribution.', 'class' => 'TooManyTrustedSignersException', ), array( 'reason' => 'One or more of your trusted signers do not exist.', 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'InvalidViewerCertificateException', ), array( 'reason' => 'This operation requires the HTTPS protocol. Ensure that you specify the HTTPS protocol in your request, or omit the RequiredProtocols element from your distribution configuration.', 'class' => 'InvalidRequiredProtocolException', ), array( 'reason' => 'No origin exists with the specified Origin Id.', 'class' => 'NoSuchOriginException', ), array( 'reason' => 'You cannot create anymore origins for the distribution.', 'class' => 'TooManyOriginsException', ), array( 'reason' => 'You cannot create anymore cache behaviors for the distribution.', 'class' => 'TooManyCacheBehaviorsException', ), array( 'reason' => 'Your request contains more cookie names in the whitelist than are allowed per cache behavior.', 'class' => 'TooManyCookieNamesInWhiteListException', ), array( 'reason' => 'Your request contains forward cookies option which doesn\'t match with the expectation for the whitelisted list of cookie names. Either list of cookie names has been specified when not allowed or list of cookie names is missing when expected.', 'class' => 'InvalidForwardCookiesException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), array( 'reason' => 'You cannot create anymore custom ssl certificates.', 'class' => 'TooManyCertificatesException', ), array( 'class' => 'InvalidLocationCodeException', ), array( 'class' => 'InvalidGeoRestrictionParameterException', ), ), ), 'UpdateStreamingDistribution' => array( 'httpMethod' => 'PUT', 'uri' => '/2013-11-11/streaming-distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateStreamingDistributionResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'StreamingDistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'required' => true, 'type' => 'string', ), 'OriginAccessIdentity' => array( 'required' => true, 'type' => 'string', ), ), ), 'Aliases' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'PriceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'reason' => 'Origin and CallerReference cannot be updated.', 'class' => 'IllegalUpdateException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'The specified streaming distribution does not exist.', 'class' => 'NoSuchStreamingDistributionException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), array( 'class' => 'TooManyStreamingDistributionCNAMEsException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The origin access identity is not valid or doesn\'t exist.', 'class' => 'InvalidOriginAccessIdentityException', ), array( 'reason' => 'Your request contains more trusted signers than are allowed per distribution.', 'class' => 'TooManyTrustedSignersException', ), array( 'reason' => 'One or more of your trusted signers do not exist.', 'class' => 'TrustedSignerDoesNotExistException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), ), 'models' => array( 'CreateCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'type' => 'string', ), 'Origins' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'IncludeCookies' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), 'ViewerCertificate' => array( 'type' => 'object', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateInvalidationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'CreateTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InvalidationBatch' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Paths' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', 'sentAs' => 'Path', ), ), ), ), 'CallerReference' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'S3Origin' => array( 'type' => 'object', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteCloudFrontOriginAccessIdentity2013_11_11Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteDistribution2013_11_11Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteStreamingDistribution2013_11_11Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetCloudFrontOriginAccessIdentityConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'type' => 'string', 'location' => 'xml', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'type' => 'string', ), 'Origins' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'IncludeCookies' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), 'ViewerCertificate' => array( 'type' => 'object', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetDistributionConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'IncludeCookies' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'PriceClass' => array( 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'type' => 'boolean', 'location' => 'xml', ), 'ViewerCertificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetInvalidationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'CreateTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InvalidationBatch' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Paths' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', 'sentAs' => 'Path', ), ), ), ), 'CallerReference' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'S3Origin' => array( 'type' => 'object', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetStreamingDistributionConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'PriceClass' => array( 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'type' => 'boolean', 'location' => 'xml', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListCloudFrontOriginAccessIdentitiesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CloudFrontOriginAccessIdentitySummary', 'type' => 'object', 'sentAs' => 'CloudFrontOriginAccessIdentitySummary', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'S3CanonicalUserId' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListDistributionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DistributionSummary', 'type' => 'object', 'sentAs' => 'DistributionSummary', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'LastModifiedTime' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Origins' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), 'ViewerCertificate' => array( 'type' => 'object', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListInvalidationsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InvalidationSummary', 'type' => 'object', 'sentAs' => 'InvalidationSummary', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'CreateTime' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListStreamingDistributionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StreamingDistributionSummary', 'type' => 'object', 'sentAs' => 'StreamingDistributionSummary', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'LastModifiedTime' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3Origin' => array( 'type' => 'object', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'type' => 'string', ), 'Origins' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'IncludeCookies' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), 'ViewerCertificate' => array( 'type' => 'object', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'S3Origin' => array( 'type' => 'object', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), ), 'waiters' => array( '__default__' => array( 'success.type' => 'output', 'success.path' => 'Status', ), 'StreamingDistributionDeployed' => array( 'operation' => 'GetStreamingDistribution', 'interval' => 60, 'max_attempts' => 25, 'success.value' => 'Deployed', ), 'DistributionDeployed' => array( 'operation' => 'GetDistribution', 'interval' => 60, 'max_attempts' => 25, 'success.value' => 'Deployed', ), 'InvalidationCompleted' => array( 'operation' => 'GetInvalidation', 'interval' => 20, 'max_attempts' => 30, 'success.value' => 'Completed', ), ), ); sdk-2.5.2/Aws/CloudSearch/CloudSearchClient.php000064411532700161006750000001065712272324172016411 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudsearch-%s.php' )) ->build(); } } sdk-2.5.2/Aws/CloudSearch/Enum/IndexFieldType.php000064411532700161006750000000146312272324172016632 0ustar '2011-02-01', 'endpointPrefix' => 'cloudsearch', 'serviceFullName' => 'Amazon CloudSearch', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'CloudSearch', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.eu-west-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.ap-southeast-1.amazonaws.com', ), ), 'operations' => array( 'CreateDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateDomainResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDomain', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), ), ), 'DefineIndexField' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DefineIndexFieldResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DefineIndexField', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'IndexField' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'IndexFieldName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'IndexFieldType' => array( 'required' => true, 'type' => 'string', ), 'UIntOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'numeric', ), ), ), 'LiteralOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), 'SearchEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'FacetEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'ResultEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TextOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), 'FacetEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'ResultEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'TextProcessor' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'SourceAttributes' => array( 'type' => 'array', 'sentAs' => 'SourceAttributes.member', 'items' => array( 'name' => 'SourceAttribute', 'type' => 'object', 'properties' => array( 'SourceDataFunction' => array( 'required' => true, 'type' => 'string', ), 'SourceDataCopy' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), ), ), 'SourceDataTrimTitle' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), 'Separator' => array( 'type' => 'string', ), 'Language' => array( 'type' => 'string', ), ), ), 'SourceDataMap' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), 'Cases' => array( 'type' => 'object', 'sentAs' => 'Cases.entry', 'additionalProperties' => array( 'type' => 'string', 'maxLength' => 1024, 'data' => array( 'shape_name' => 'FieldValue', ), ), ), ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DefineRankExpression' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DefineRankExpressionResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DefineRankExpression', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'RankExpression' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'RankName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'RankExpression' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 10240, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeleteDomainResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDomain', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), ), ), 'DeleteIndexField' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeleteIndexFieldResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteIndexField', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'IndexFieldName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteRankExpression' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeleteRankExpressionResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRankExpression', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'RankName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeDefaultSearchField' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeDefaultSearchFieldResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDefaultSearchField', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeDomains' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeDomainsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDomains', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DomainNames.member', 'items' => array( 'name' => 'DomainName', 'type' => 'string', 'minLength' => 3, 'maxLength' => 28, ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), ), ), 'DescribeIndexFields' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeIndexFieldsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeIndexFields', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'FieldNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'FieldNames.member', 'items' => array( 'name' => 'FieldName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeRankExpressions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeRankExpressionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeRankExpressions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'RankNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'RankNames.member', 'items' => array( 'name' => 'FieldName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeServiceAccessPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeServiceAccessPoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeServiceAccessPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeStemmingOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStemmingOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStemmingOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeStopwordOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStopwordOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStopwordOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeSynonymOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSynonymOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSynonymOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'IndexDocuments' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'IndexDocumentsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'IndexDocuments', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateDefaultSearchField' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateDefaultSearchFieldResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateDefaultSearchField', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'DefaultSearchField' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateServiceAccessPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateServiceAccessPoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateServiceAccessPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'AccessPolicies' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), ), ), 'UpdateStemmingOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateStemmingOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateStemmingOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'Stems' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateStopwordOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateStopwordOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateStopwordOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'Stopwords' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateSynonymOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateSynonymOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateSynonymOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'Synonyms' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), ), 'models' => array( 'CreateDomainResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DomainStatus' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainId' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'Created' => array( 'type' => 'boolean', ), 'Deleted' => array( 'type' => 'boolean', ), 'NumSearchableDocs' => array( 'type' => 'numeric', ), 'DocService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'SearchService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'RequiresIndexDocuments' => array( 'type' => 'boolean', ), 'Processing' => array( 'type' => 'boolean', ), 'SearchInstanceType' => array( 'type' => 'string', ), 'SearchPartitionCount' => array( 'type' => 'numeric', ), 'SearchInstanceCount' => array( 'type' => 'numeric', ), ), ), ), ), 'DefineIndexFieldResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IndexField' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'IndexFieldName' => array( 'type' => 'string', ), 'IndexFieldType' => array( 'type' => 'string', ), 'UIntOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'numeric', ), ), ), 'LiteralOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'SearchEnabled' => array( 'type' => 'boolean', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), ), ), 'TextOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), 'TextProcessor' => array( 'type' => 'string', ), ), ), 'SourceAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceAttribute', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SourceDataFunction' => array( 'type' => 'string', ), 'SourceDataCopy' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), ), ), 'SourceDataTrimTitle' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Separator' => array( 'type' => 'string', ), 'Language' => array( 'type' => 'string', ), ), ), 'SourceDataMap' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Cases' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), ), ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DefineRankExpressionResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RankExpression' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'RankName' => array( 'type' => 'string', ), 'RankExpression' => array( 'type' => 'string', ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DeleteDomainResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DomainStatus' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainId' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'Created' => array( 'type' => 'boolean', ), 'Deleted' => array( 'type' => 'boolean', ), 'NumSearchableDocs' => array( 'type' => 'numeric', ), 'DocService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'SearchService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'RequiresIndexDocuments' => array( 'type' => 'boolean', ), 'Processing' => array( 'type' => 'boolean', ), 'SearchInstanceType' => array( 'type' => 'string', ), 'SearchPartitionCount' => array( 'type' => 'numeric', ), 'SearchInstanceCount' => array( 'type' => 'numeric', ), ), ), ), ), 'DeleteIndexFieldResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IndexField' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'IndexFieldName' => array( 'type' => 'string', ), 'IndexFieldType' => array( 'type' => 'string', ), 'UIntOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'numeric', ), ), ), 'LiteralOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'SearchEnabled' => array( 'type' => 'boolean', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), ), ), 'TextOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), 'TextProcessor' => array( 'type' => 'string', ), ), ), 'SourceAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceAttribute', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SourceDataFunction' => array( 'type' => 'string', ), 'SourceDataCopy' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), ), ), 'SourceDataTrimTitle' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Separator' => array( 'type' => 'string', ), 'Language' => array( 'type' => 'string', ), ), ), 'SourceDataMap' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Cases' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), ), ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DeleteRankExpressionResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RankExpression' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'RankName' => array( 'type' => 'string', ), 'RankExpression' => array( 'type' => 'string', ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeDefaultSearchFieldResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DefaultSearchField' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeDomainsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DomainStatusList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DomainStatus', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'DomainId' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'Created' => array( 'type' => 'boolean', ), 'Deleted' => array( 'type' => 'boolean', ), 'NumSearchableDocs' => array( 'type' => 'numeric', ), 'DocService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'SearchService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'RequiresIndexDocuments' => array( 'type' => 'boolean', ), 'Processing' => array( 'type' => 'boolean', ), 'SearchInstanceType' => array( 'type' => 'string', ), 'SearchPartitionCount' => array( 'type' => 'numeric', ), 'SearchInstanceCount' => array( 'type' => 'numeric', ), ), ), ), ), ), 'DescribeIndexFieldsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IndexFields' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'IndexFieldStatus', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'IndexFieldName' => array( 'type' => 'string', ), 'IndexFieldType' => array( 'type' => 'string', ), 'UIntOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'numeric', ), ), ), 'LiteralOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'SearchEnabled' => array( 'type' => 'boolean', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), ), ), 'TextOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), 'TextProcessor' => array( 'type' => 'string', ), ), ), 'SourceAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceAttribute', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SourceDataFunction' => array( 'type' => 'string', ), 'SourceDataCopy' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), ), ), 'SourceDataTrimTitle' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Separator' => array( 'type' => 'string', ), 'Language' => array( 'type' => 'string', ), ), ), 'SourceDataMap' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Cases' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), ), ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'DescribeRankExpressionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RankExpressions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'RankExpressionStatus', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'RankName' => array( 'type' => 'string', ), 'RankExpression' => array( 'type' => 'string', ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'DescribeServiceAccessPoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccessPolicies' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeStemmingOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stems' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeStopwordOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stopwords' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeSynonymOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Synonyms' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'IndexDocumentsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'FieldNames' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'FieldName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'UpdateDefaultSearchFieldResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DefaultSearchField' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'UpdateServiceAccessPoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccessPolicies' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'UpdateStemmingOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stems' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'UpdateStopwordOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stopwords' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'UpdateSynonymOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Synonyms' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeDomains' => array( 'result_key' => 'DomainStatusList', ), 'DescribeIndexFields' => array( 'result_key' => 'IndexFields', ), 'DescribeRankExpressions' => array( 'result_key' => 'RankExpressions', ), ), ), ); sdk-2.5.2/Aws/CloudTrail/CloudTrailClient.php000064411532700161006750000000530112272324172016113 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudtrail-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } sdk-2.5.2/Aws/CloudTrail/LogFileIterator.php000064411532700161006750000002607312272324172015756 0ustar describeTrails(array( 'trailNameList' => array($trailName), )); $s3BucketName = $result->getPath('trailList/0/S3BucketName'); $options[self::KEY_PREFIX] = $result->getPath('trailList/0/S3KeyPrefix'); } catch (CloudTrailException $e) { // There was an error describing the trail } // If the bucket name is still unknown, then throw an exception if (!$s3BucketName) { $prev = isset($e) ? $e : null; throw new InvalidArgumentException('The bucket name could not be determined from the trail.', 0, $prev); } return new self($s3Client, $s3BucketName, $options); } /** * Constructs a LogFileIterator using the specified options: * * - trail_name: The name of the trail that is generating our logs. If none is provided, then "Default" will be * used, since that is the name of the trail created in the AWS Management Console. * - key_prefix: The S3 key prefix of your log files. This value will be overwritten when using the `fromTrail()` * method. However, if you are using the constructor, then this value will be used. * - start_date: The timestamp of the beginning of date range of the log records you want to read. You can pass this * in as a `DateTime` object, integer (unix timestamp), or a string compatible with `strtotime()`. * - end_date: The timestamp of the end of date range of the log records you want to read. You can pass this in as * a `DateTime` object, integer (unix timestamp), or a string compatible with `strtotime()`. * - account_id: This is your AWS account ID, which is the 12-digit number found on the *Account Identifiers* * section of the *AWS Security Credentials* page. See https://console.aws.amazon.com/iam/home?#security_credential * - log_region: The region of the services of the log records you want to read. * * @param S3Client $s3Client * @param string $s3BucketName * @param array $options */ public function __construct(S3Client $s3Client, $s3BucketName, array $options = array()) { $this->s3Client = $s3Client; $this->s3BucketName = $s3BucketName; parent::__construct($this->buildListObjectsIterator($options)); } /** * An override of the typical current behavior of \IteratorIterator to format the output such that the bucket and * key are returned in an array * * @return array|bool */ public function current() { if ($object = parent::current()) { return array( 'Bucket' => $this->s3BucketName, 'Key' => $object['Key'] ); } return false; } /** * Constructs an S3 ListObjects iterator, optionally decorated with FilterIterators, based on the provided options * * @param array $options * * @return \Iterator */ private function buildListObjectsIterator(array $options) { // Extract and normalize the date values from the options $startDate = isset($options[self::START_DATE]) ? $this->normalizeDateValue($options[self::START_DATE]) : null; $endDate = isset($options[self::END_DATE]) ? $this->normalizeDateValue($options[self::END_DATE]) : null; // Determine the parts of the key prefix of the log files being read $keyPrefixParts = array( 'prefix' => isset($options[self::KEY_PREFIX]) ? $options[self::KEY_PREFIX] : null, 'account' => isset($options[self::ACCOUNT_ID]) ? $options[self::ACCOUNT_ID] : self::PREFIX_WILDCARD, 'region' => isset($options[self::LOG_REGION]) ? $options[self::LOG_REGION] : self::PREFIX_WILDCARD, 'date' => $this->determineDateForPrefix($startDate, $endDate), ); // Determine the longest key prefix that can be used to retrieve all of the relevant log files $candidatePrefix = ltrim(strtr(self::PREFIX_TEMPLATE, $keyPrefixParts), '/'); $logKeyPrefix = $candidatePrefix; if (($index = strpos($candidatePrefix, self::PREFIX_WILDCARD)) !== false) { $logKeyPrefix = substr($candidatePrefix, 0, $index); } // Create an iterator that will emit all of the objects matching the key prefix $objectsIterator = $this->s3Client->getListObjectsIterator(array( 'Bucket' => $this->s3BucketName, 'Prefix' => $logKeyPrefix, )); // Apply regex and/or date filters to the objects iterator to emit only log files matching the options $objectsIterator = $this->applyRegexFilter($objectsIterator, $logKeyPrefix, $candidatePrefix); $objectsIterator = $this->applyDateFilter($objectsIterator, $startDate, $endDate); return $objectsIterator; } /** * Normalizes a date value to a unix timestamp * * @param string|\DateTime|int $date * * @return int * @throws \InvalidArgumentException if the value cannot be converted to a timestamp */ private function normalizeDateValue($date) { // Normalize start date to a unix timestamp if (is_string($date)) { $date = strtotime($date); } elseif ($date instanceof \DateTime) { $date = $date->format('U'); } elseif (!is_int($date)) { throw new \InvalidArgumentException('Date values must be a string, an int, or a DateTime object.'); } return $date; } /** * Uses the provided date values to determine the date portion of the prefix */ private function determineDateForPrefix($startDate, $endDate) { // The default date value should look like "*/*/*" after joining $dateParts = array_fill_keys(array('Y', 'm', 'd'), self::PREFIX_WILDCARD); // Narrow down the date by replacing the WILDCARDs with values if they are the same for the start and end date if ($startDate && $endDate) { foreach ($dateParts as $key => &$value) { $candidateValue = date($key, $startDate); if ($candidateValue === date($key, $endDate)) { $value = $candidateValue; } else { break; } } } return join('/', $dateParts); } /** * Applies a regex iterator filter that limits the ListObjects result set based on the provided options * * @param \Iterator $objectsIterator * @param string $logKeyPrefix * @param string $candidatePrefix * * @return \Iterator */ private function applyRegexFilter($objectsIterator, $logKeyPrefix, $candidatePrefix) { // If the prefix and candidate prefix are not the same, then there were WILDCARDs if ($logKeyPrefix !== $candidatePrefix) { // Turn the candidate prefix into a regex by trimming and converting WILDCARDs to regex notation $regex = rtrim($candidatePrefix, '/' . self::PREFIX_WILDCARD) . '/'; $regex = strtr($regex, array(self::PREFIX_WILDCARD => '[^/]+')); // After trimming WILDCARDs or the end, if the regex is the same as the prefix, then no regex is needed if ($logKeyPrefix !== $regex) { // Apply a regex filter iterator to remove files that don't match the provided options $objectsIterator = new FilterIterator($objectsIterator, function ($object) use ($regex) { return preg_match("#{$regex}#", $object['Key']); }); } } return $objectsIterator; } /** * Applies an iterator filter to restrict the ListObjects result set to the specified date range * * @param \Iterator $objectsIterator * @param int $startDate * @param int $endDate * * @return \Iterator */ private function applyDateFilter($objectsIterator, $startDate, $endDate) { // If either a start or end date was provided, filter out dates that don't match the date range if ($startDate || $endDate) { $objectsIterator = new FilterIterator($objectsIterator, function ($object) use ($startDate, $endDate) { if (preg_match('/[0-9]{8}T[0-9]{4}Z/', $object['Key'], $matches)) { $date = strtotime($matches[0]); if ((!$startDate || $date >= $startDate) && (!$endDate || $date <= $endDate)) { return true; } } return false; }); } return $objectsIterator; } } sdk-2.5.2/Aws/CloudTrail/LogFileReader.php000064411532700161006750000000340412272324172015360 0ustar s3Client = $s3Client; } /** * Downloads, unzips, and reads a CloudTrail log file from Amazon S3 * * @param string $s3BucketName The bucket name of the log file in Amazon S3 * @param string $logFileKey The key of the log file in Amazon S3 * * @return array */ public function read($s3BucketName, $logFileKey) { // Create a command for getting the log file object $command = $this->s3Client->getCommand('GetObject', array( 'Bucket' => (string) $s3BucketName, 'Key' => (string) $logFileKey, )); // Make sure gzip encoding header is sent and accepted in order to inflate the response data $command->set('ResponseContentEncoding', 'x-gzip'); $command->prepare()->addHeader('Accept-Encoding', 'gzip'); // Get the JSON response data and extract the log records $command->execute(); $logData = $command->getResponse()->json(); if (isset($logData['Records'])) { return $logData['Records']; } else { return array(); } } } sdk-2.5.2/Aws/CloudTrail/LogRecordIterator.php000064411532700161006750000001265512272324172016316 0ustar $s3BucketName, 'Key' => $s3ObjectKey, ))); return new self($logFileReader, $logFileIterator); } /** * @param LogFileReader $logFileReader * @param \Iterator $logFileIterator */ public function __construct(LogFileReader $logFileReader, \Iterator $logFileIterator) { $this->logFileReader = $logFileReader; $this->logFileIterator = $logFileIterator; $this->records = array(); $this->recordIndex = 0; } /** * Returns the current log record as a Guzzle Collection object. This object behaves like an associative array * except that it returns `null` on non-existent keys instead of causing an error. See the linked resources for the * schema of the log record data and how to work with Guzzle Collections. * * @return Collection * @link http://docs.aws.amazon.com/awscloudtrail/latest/userguide/eventreference.html * @link http://api.guzzlephp.org/class-Guzzle.Common.Collection.html */ public function current() { if ($this->valid()) { return new Collection($this->records[$this->recordIndex]); } else { return false; } } public function next() { $this->recordIndex++; // If all the records have been exhausted, get more records from the next log file while (!$this->valid()) { $this->logFileIterator->next(); $success = $this->loadRecordsFromCurrentLogFile(); if (!$success) { // The objects iterator is exhausted as well, so stop trying break; } } } public function key() { if ($logFile = $this->logFileIterator->current()) { return $logFile['Key'] . '.' . $this->recordIndex; } else { return null; } } public function valid() { return isset($this->records[$this->recordIndex]); } public function rewind() { $this->logFileIterator->rewind(); $this->loadRecordsFromCurrentLogFile(); } public function getInnerIterator() { return $this->logFileIterator; } /** * Examines the current file in the `logFileIterator` and attempts to read it and load log records from it using * the `logFileReader`. This method expects that items pulled from the iterator will take the form: * * array( * 'Bucket' => '...', * 'Key' => '...', * ) * * @return bool Returns `true` if records were loaded and `false` if no records were found */ private function loadRecordsFromCurrentLogFile() { $this->recordIndex = 0; $this->records = array(); $logFile = $this->logFileIterator->current(); if ($logFile && isset($logFile['Bucket']) && isset($logFile['Key'])) { $this->records = $this->logFileReader->read($logFile['Bucket'], $logFile['Key']); } return (bool) $logFile; } } sdk-2.5.2/Aws/CloudTrail/Exception/CloudTrailException.php000064411532700161006750000000142212272324172020571 0ustar '2013-11-01', 'endpointPrefix' => 'cloudtrail', 'serviceFullName' => 'AWS CloudTrail', 'serviceAbbreviation' => 'CloudTrail', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.', 'signatureVersion' => 'v4', 'namespace' => 'CloudTrail', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudtrail.us-east-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudtrail.us-west-2.amazonaws.com', ), ), 'operations' => array( 'CreateTrail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateTrailResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.CreateTrail', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'S3BucketName' => array( 'type' => 'string', 'location' => 'json', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'json', ), 'SnsTopicName' => array( 'type' => 'string', 'location' => 'json', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'trail' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the maximum number of trails is reached.', 'class' => 'MaximumNumberOfTrailsExceededException', ), array( 'reason' => 'This exception is thrown when the specified trail already exists.', 'class' => 'TrailAlreadyExistsException', ), array( 'reason' => 'This exception is thrown when the specified S3 bucket does not exist.', 'class' => 'S3BucketDoesNotExistException', ), array( 'reason' => 'This exception is thrown when the policy on the S3 bucket is not sufficient.', 'class' => 'InsufficientS3BucketPolicyException', ), array( 'reason' => 'This exception is thrown when the policy on the SNS topic is not sufficient.', 'class' => 'InsufficientSnsTopicPolicyException', ), array( 'reason' => 'This exception is thrown when the provided S3 bucket name is not valid.', 'class' => 'InvalidS3BucketNameException', ), array( 'reason' => 'This exception is thrown when the provided S3 prefix is not valid.', 'class' => 'InvalidS3PrefixException', ), array( 'reason' => 'This exception is thrown when the provided SNS topic name is not valid.', 'class' => 'InvalidSnsTopicNameException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), array( 'reason' => 'This exception is thrown when no trail is provided.', 'class' => 'TrailNotProvidedException', ), ), ), 'DeleteTrail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.DeleteTrail', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), ), ), 'DescribeTrails' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrailsResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.DescribeTrails', ), 'trailNameList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'GetTrailStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetTrailStatusResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.GetTrailStatus', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), ), ), 'StartLogging' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.StartLogging', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), ), ), 'StopLogging' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.StopLogging', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), ), ), 'UpdateTrail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateTrailResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.UpdateTrail', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'S3BucketName' => array( 'type' => 'string', 'location' => 'json', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'json', ), 'SnsTopicName' => array( 'type' => 'string', 'location' => 'json', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'trail' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the specified S3 bucket does not exist.', 'class' => 'S3BucketDoesNotExistException', ), array( 'reason' => 'This exception is thrown when the policy on the S3 bucket is not sufficient.', 'class' => 'InsufficientS3BucketPolicyException', ), array( 'reason' => 'This exception is thrown when the policy on the SNS topic is not sufficient.', 'class' => 'InsufficientSnsTopicPolicyException', ), array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided S3 bucket name is not valid.', 'class' => 'InvalidS3BucketNameException', ), array( 'reason' => 'This exception is thrown when the provided S3 prefix is not valid.', 'class' => 'InvalidS3PrefixException', ), array( 'reason' => 'This exception is thrown when the provided SNS topic name is not valid.', 'class' => 'InvalidSnsTopicNameException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), array( 'reason' => 'This exception is thrown when no trail is provided.', 'class' => 'TrailNotProvidedException', ), ), ), ), 'models' => array( 'CreateTrailResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'S3BucketName' => array( 'type' => 'string', 'location' => 'json', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'json', ), 'SnsTopicName' => array( 'type' => 'string', 'location' => 'json', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'location' => 'json', ), 'trail' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeTrailsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'trailList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Trail', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', ), ), ), ), ), ), 'GetTrailStatusResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IsLogging' => array( 'type' => 'boolean', 'location' => 'json', ), 'LatestDeliveryError' => array( 'type' => 'string', 'location' => 'json', ), 'LatestNotificationError' => array( 'type' => 'string', 'location' => 'json', ), 'LatestDeliveryTime' => array( 'type' => 'string', 'location' => 'json', ), 'LatestNotificationTime' => array( 'type' => 'string', 'location' => 'json', ), 'StartLoggingTime' => array( 'type' => 'string', 'location' => 'json', ), 'StopLoggingTime' => array( 'type' => 'string', 'location' => 'json', ), 'LatestDeliveryAttemptTime' => array( 'type' => 'string', 'location' => 'json', ), 'LatestNotificationAttemptTime' => array( 'type' => 'string', 'location' => 'json', ), 'LatestNotificationAttemptSucceeded' => array( 'type' => 'string', 'location' => 'json', ), 'LatestDeliveryAttemptSucceeded' => array( 'type' => 'string', 'location' => 'json', ), 'TimeLoggingStarted' => array( 'type' => 'string', 'location' => 'json', ), 'TimeLoggingStopped' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateTrailResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'S3BucketName' => array( 'type' => 'string', 'location' => 'json', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'json', ), 'SnsTopicName' => array( 'type' => 'string', 'location' => 'json', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'location' => 'json', ), 'trail' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeTrails' => array( 'result_key' => 'trailList', ), ), ), ); sdk-2.5.2/Aws/CloudWatch/CloudWatchClient.php000064411532700161006750000000704112272324172016104 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudwatch-%s.php' )) ->build(); } } sdk-2.5.2/Aws/CloudWatch/Enum/ComparisonOperator.php000064411532700161006750000000176312272324172017447 0ustar '2010-08-01', 'endpointPrefix' => 'monitoring', 'serviceFullName' => 'Amazon CloudWatch', 'serviceAbbreviation' => 'CloudWatch', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'CloudWatch', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'monitoring.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'DeleteAlarms' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAlarms', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmNames.member', 'maxItems' => 100, 'items' => array( 'name' => 'AlarmName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), 'errorResponses' => array( array( 'reason' => 'The named resource does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeAlarmHistory' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAlarmHistoryOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAlarmHistory', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'HistoryItemType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 100, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The next token specified is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeAlarms' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAlarmsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAlarms', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmNames.member', 'maxItems' => 100, 'items' => array( 'name' => 'AlarmName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'AlarmNamePrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'StateValue' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ActionPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 100, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The next token specified is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeAlarmsForMetric' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAlarmsForMetricOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAlarmsForMetric', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'MetricName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Namespace' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Statistic' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Dimensions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'Period' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 60, ), 'Unit' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DisableAlarmActions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableAlarmActions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmNames.member', 'maxItems' => 100, 'items' => array( 'name' => 'AlarmName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'EnableAlarmActions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableAlarmActions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmNames.member', 'maxItems' => 100, 'items' => array( 'name' => 'AlarmName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'GetMetricStatistics' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetMetricStatisticsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetMetricStatistics', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'Namespace' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'MetricName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Dimensions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'StartTime' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Period' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 60, ), 'Statistics' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Statistics.member', 'minItems' => 1, 'maxItems' => 5, 'items' => array( 'name' => 'Statistic', 'type' => 'string', ), ), 'Unit' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Bad or out-of-range value was supplied for the input parameter.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'An input parameter that is mandatory for processing the request is not supplied.', 'class' => 'MissingRequiredParameterException', ), array( 'reason' => 'Parameters that must not be used together were used together.', 'class' => 'InvalidParameterCombinationException', ), array( 'reason' => 'Indicates that the request processing has failed due to some unknown error, exception, or failure.', 'class' => 'InternalServiceException', ), ), ), 'ListMetrics' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListMetricsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListMetrics', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'Namespace' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'MetricName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Dimensions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'DimensionFilter', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the request processing has failed due to some unknown error, exception, or failure.', 'class' => 'InternalServiceException', ), array( 'reason' => 'Bad or out-of-range value was supplied for the input parameter.', 'class' => 'InvalidParameterValueException', ), ), ), 'PutMetricAlarm' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutMetricAlarm', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'AlarmDescription' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 255, ), 'ActionsEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'OKActions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OKActions.member', 'maxItems' => 5, 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'AlarmActions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmActions.member', 'maxItems' => 5, 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'InsufficientDataActions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InsufficientDataActions.member', 'maxItems' => 5, 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'MetricName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Namespace' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Statistic' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Dimensions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'Period' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 60, ), 'Unit' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EvaluationPeriods' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, ), 'Threshold' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The quota for alarms for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'PutMetricData' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutMetricData', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'Namespace' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'MetricData' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'MetricData.member', 'items' => array( 'name' => 'MetricDatum', 'type' => 'object', 'properties' => array( 'MetricName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Dimensions' => array( 'type' => 'array', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'Timestamp' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', ), 'Value' => array( 'type' => 'numeric', ), 'StatisticValues' => array( 'type' => 'object', 'properties' => array( 'SampleCount' => array( 'required' => true, 'type' => 'numeric', ), 'Sum' => array( 'required' => true, 'type' => 'numeric', ), 'Minimum' => array( 'required' => true, 'type' => 'numeric', ), 'Maximum' => array( 'required' => true, 'type' => 'numeric', ), ), ), 'Unit' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Bad or out-of-range value was supplied for the input parameter.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'An input parameter that is mandatory for processing the request is not supplied.', 'class' => 'MissingRequiredParameterException', ), array( 'reason' => 'Parameters that must not be used together were used together.', 'class' => 'InvalidParameterCombinationException', ), array( 'reason' => 'Indicates that the request processing has failed due to some unknown error, exception, or failure.', 'class' => 'InternalServiceException', ), ), ), 'SetAlarmState' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetAlarmState', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'StateValue' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'StateReason' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 1023, ), 'StateReasonData' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 4000, ), ), 'errorResponses' => array( array( 'reason' => 'The named resource does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Data was not syntactically valid JSON.', 'class' => 'InvalidFormatException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeAlarmHistoryOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AlarmHistoryItems' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AlarmHistoryItem', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AlarmName' => array( 'type' => 'string', ), 'Timestamp' => array( 'type' => 'string', ), 'HistoryItemType' => array( 'type' => 'string', ), 'HistorySummary' => array( 'type' => 'string', ), 'HistoryData' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeAlarmsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MetricAlarms' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MetricAlarm', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AlarmName' => array( 'type' => 'string', ), 'AlarmArn' => array( 'type' => 'string', ), 'AlarmDescription' => array( 'type' => 'string', ), 'AlarmConfigurationUpdatedTimestamp' => array( 'type' => 'string', ), 'ActionsEnabled' => array( 'type' => 'boolean', ), 'OKActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'AlarmActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'InsufficientDataActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'StateValue' => array( 'type' => 'string', ), 'StateReason' => array( 'type' => 'string', ), 'StateReasonData' => array( 'type' => 'string', ), 'StateUpdatedTimestamp' => array( 'type' => 'string', ), 'MetricName' => array( 'type' => 'string', ), 'Namespace' => array( 'type' => 'string', ), 'Statistic' => array( 'type' => 'string', ), 'Dimensions' => array( 'type' => 'array', 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'Period' => array( 'type' => 'numeric', ), 'Unit' => array( 'type' => 'string', ), 'EvaluationPeriods' => array( 'type' => 'numeric', ), 'Threshold' => array( 'type' => 'numeric', ), 'ComparisonOperator' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeAlarmsForMetricOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MetricAlarms' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MetricAlarm', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AlarmName' => array( 'type' => 'string', ), 'AlarmArn' => array( 'type' => 'string', ), 'AlarmDescription' => array( 'type' => 'string', ), 'AlarmConfigurationUpdatedTimestamp' => array( 'type' => 'string', ), 'ActionsEnabled' => array( 'type' => 'boolean', ), 'OKActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'AlarmActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'InsufficientDataActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'StateValue' => array( 'type' => 'string', ), 'StateReason' => array( 'type' => 'string', ), 'StateReasonData' => array( 'type' => 'string', ), 'StateUpdatedTimestamp' => array( 'type' => 'string', ), 'MetricName' => array( 'type' => 'string', ), 'Namespace' => array( 'type' => 'string', ), 'Statistic' => array( 'type' => 'string', ), 'Dimensions' => array( 'type' => 'array', 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'Period' => array( 'type' => 'numeric', ), 'Unit' => array( 'type' => 'string', ), 'EvaluationPeriods' => array( 'type' => 'numeric', ), 'Threshold' => array( 'type' => 'numeric', ), 'ComparisonOperator' => array( 'type' => 'string', ), ), ), ), ), ), 'GetMetricStatisticsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Label' => array( 'type' => 'string', 'location' => 'xml', ), 'Datapoints' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Datapoint', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Timestamp' => array( 'type' => 'string', ), 'SampleCount' => array( 'type' => 'numeric', ), 'Average' => array( 'type' => 'numeric', ), 'Sum' => array( 'type' => 'numeric', ), 'Minimum' => array( 'type' => 'numeric', ), 'Maximum' => array( 'type' => 'numeric', ), 'Unit' => array( 'type' => 'string', ), ), ), ), ), ), 'ListMetricsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Metrics' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Metric', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'MetricName' => array( 'type' => 'string', ), 'Dimensions' => array( 'type' => 'array', 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeAlarmHistory' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'AlarmHistoryItems', ), 'DescribeAlarms' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'MetricAlarms', ), 'DescribeAlarmsForMetric' => array( 'result_key' => 'MetricAlarms', ), 'ListMetrics' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Metrics', ), ), ), ); sdk-2.5.2/Aws/Common/Aws.php000064411532700161006750000000712612272324172012641 0ustar addAlias('_aws', self::getDefaultServiceDefinition()) ->addAlias('_sdk1', __DIR__ . '/Resources/sdk1-config.php'); return $loader->load($config, $globalParameters); } /** * Get the full path to the default service builder definition file * * @return string */ public static function getDefaultServiceDefinition() { return __DIR__ . '/Resources/aws-config.php'; } /** * Returns the configuration for the service builder * * @return array */ public function getConfig() { return $this->builderConfig; } /** * Enables the facades for the clients defined in the service builder * * @param string|null $namespace The namespace that the facades should be mounted to. Defaults to global namespace * * @return Aws */ public function enableFacades($namespace = null) { Facade::mountFacades($this, $namespace); return $this; } } sdk-2.5.2/Aws/Common/Enum.php000064411532700161006750000000262112272324172013006 0ustar getConstants(); } return self::$cache[$class]; } } sdk-2.5.2/Aws/Common/HostNameUtils.php000064411532700161006750000000465512272324172014652 0ustar getHost(), -14) != '.amazonaws.com') { return self::DEFAULT_REGION; } $serviceAndRegion = substr($url->getHost(), 0, -14); // Special handling for S3 regions $separator = strpos($serviceAndRegion, 's3') === 0 ? '-' : '.'; $separatorPos = strpos($serviceAndRegion, $separator); // If don't detect a separator, then return the default region if ($separatorPos === false) { return self::DEFAULT_REGION; } $region = substr($serviceAndRegion, $separatorPos + 1); // All GOV regions currently use the default GOV region if ($region == 'us-gov') { return self::DEFAULT_GOV_REGION; } return $region; } /** * Parse the AWS service name from a URL * * @param Url $url HTTP URL * * @return string Returns a service name (or empty string) * @link http://docs.aws.amazon.com/general/latest/gr/rande.html */ public static function parseServiceName(Url $url) { // The service name is the first part of the host $parts = explode('.', $url->getHost(), 2); // Special handling for S3 if (stripos($parts[0], 's3') === 0) { return 's3'; } return $parts[0]; } } sdk-2.5.2/Aws/Common/Client/AbstractClient.php000064411532700161006750000002244012272324172016223 0ustar get(Options::BASE_URL), $config); $this->credentials = $credentials; $this->signature = $signature; // Make sure the user agent is prefixed by the SDK version $this->setUserAgent('aws-sdk-php2/' . Aws::VERSION, true); // Add the event listener so that requests are signed before they are sent $dispatcher = $this->getEventDispatcher(); $dispatcher->addSubscriber(new SignatureListener($credentials, $signature)); if ($backoff = $config->get(Options::BACKOFF)) { $dispatcher->addSubscriber($backoff, -255); } } public function __call($method, $args) { if (substr($method, 0, 3) === 'get' && substr($method, -8) === 'Iterator') { // Allow magic method calls for iterators (e.g. $client->getIterator($params)) $commandOptions = isset($args[0]) ? $args[0] : null; $iteratorOptions = isset($args[1]) ? $args[1] : array(); return $this->getIterator(substr($method, 3, -8), $commandOptions, $iteratorOptions); } elseif (substr($method, 0, 9) == 'waitUntil') { // Allow magic method calls for waiters (e.g. $client->waitUntil($params)) return $this->waitUntil(substr($method, 9), isset($args[0]) ? $args[0]: array()); } else { return parent::__call(ucfirst($method), $args); } } /** * Get an endpoint for a specific region from a service description * * @param ServiceDescriptionInterface $description Service description * @param string $region Region of the endpoint * @param string $scheme URL scheme * * @return string * @throws InvalidArgumentException */ public static function getEndpoint(ServiceDescriptionInterface $description, $region, $scheme) { $service = $description->getData('serviceFullName'); // Lookup the region in the service description if (!($regions = $description->getData('regions'))) { throw new InvalidArgumentException("No regions found in the {$service} description"); } // Ensure that the region exists for the service if (!isset($regions[$region])) { throw new InvalidArgumentException("{$region} is not a valid region for {$service}"); } // Ensure that the scheme is valid if ($regions[$region][$scheme] == false) { throw new InvalidArgumentException("{$scheme} is not a valid URI scheme for {$service} in {$region}"); } return $scheme . '://' . $regions[$region]['hostname']; } /** * {@inheritdoc} */ public function getCredentials() { return $this->credentials; } /** * {@inheritdoc} */ public function setCredentials(CredentialsInterface $credentials) { $formerCredentials = $this->credentials; $this->credentials = $credentials; // Dispatch an event that the credentials have been changed $this->dispatch('client.credentials_changed', array( 'credentials' => $credentials, 'former_credentials' => $formerCredentials, )); return $this; } /** * {@inheritdoc} */ public function getSignature() { return $this->signature; } /** * {@inheritdoc} */ public function getRegions() { return $this->serviceDescription->getData('regions'); } /** * {@inheritdoc} */ public function getRegion() { return $this->getConfig(Options::REGION); } /** * {@inheritdoc} */ public function setRegion($region) { $config = $this->getConfig(); $formerRegion = $config->get(Options::REGION); $global = $this->serviceDescription->getData('globalEndpoint'); // Only change the region if the service does not have a global endpoint if (!$global || $this->serviceDescription->getData('namespace') === 'S3') { $baseUrl = self::getEndpoint($this->serviceDescription, $region, $config->get(Options::SCHEME)); $this->setBaseUrl($baseUrl); $config->set(Options::BASE_URL, $baseUrl)->set(Options::REGION, $region); // Update the signature if necessary $signature = $this->getSignature(); if ($signature instanceof EndpointSignatureInterface) { /** @var $signature EndpointSignatureInterface */ $signature->setRegionName($region); } // Dispatch an event that the region has been changed $this->dispatch('client.region_changed', array( 'region' => $region, 'former_region' => $formerRegion, )); } return $this; } /** * {@inheritdoc} */ public function waitUntil($waiter, array $input = array()) { $this->getWaiter($waiter, $input)->wait(); return $this; } /** * {@inheritdoc} */ public function getWaiter($waiter, array $input = array()) { return $this->getWaiterFactory()->build($waiter) ->setClient($this) ->setConfig($input); } /** * {@inheritdoc} */ public function setWaiterFactory(WaiterFactoryInterface $waiterFactory) { $this->waiterFactory = $waiterFactory; return $this; } /** * {@inheritdoc} */ public function getWaiterFactory() { if (!$this->waiterFactory) { $clientClass = get_class($this); // Use a composite factory that checks for classes first, then config waiters $this->waiterFactory = new CompositeWaiterFactory(array( new WaiterClassFactory(substr($clientClass, 0, strrpos($clientClass, '\\')) . '\\Waiter') )); if ($this->getDescription()) { $waiterConfig = $this->getDescription()->getData('waiters') ?: array(); $this->waiterFactory->addFactory(new WaiterConfigFactory($waiterConfig)); } } return $this->waiterFactory; } /** * {@inheritdoc} */ public function getApiVersion() { return $this->serviceDescription->getApiVersion(); } /** * {@inheritdoc} * @throws \Aws\Common\Exception\TransferException */ public function send($requests) { try { return parent::send($requests); } catch (CurlException $e) { $wrapped = new TransferException($e->getMessage(), null, $e); $wrapped->setCurlHandle($e->getCurlHandle()) ->setCurlInfo($e->getCurlInfo()) ->setError($e->getError(), $e->getErrorNo()) ->setRequest($e->getRequest()); throw $wrapped; } } } sdk-2.5.2/Aws/Common/Client/AwsClientInterface.php000064411532700161006750000000627212272324172017040 0ustar 'https'); /** * @var array Default client requirements */ protected static $commonConfigRequirements = array(Options::SERVICE_DESCRIPTION); /** * @var string The namespace of the client */ protected $clientNamespace; /** * @var array The config options */ protected $config = array(); /** * @var array The config defaults */ protected $configDefaults = array(); /** * @var array The config requirements */ protected $configRequirements = array(); /** * @var ExceptionParserInterface The Parser interface for the client */ protected $exceptionParser; /** * @var array Array of configuration data for iterators available for the client */ protected $iteratorsConfig = array(); /** * Factory method for creating the client builder * * @param string $namespace The namespace of the client * * @return ClientBuilder */ public static function factory($namespace = null) { return new static($namespace); } /** * Constructs a client builder * * @param string $namespace The namespace of the client */ public function __construct($namespace = null) { $this->clientNamespace = $namespace; } /** * Sets the config options * * @param array|Collection $config The config options * * @return ClientBuilder */ public function setConfig($config) { $this->config = $this->processArray($config); return $this; } /** * Sets the config options' defaults * * @param array|Collection $defaults The default values * * @return ClientBuilder */ public function setConfigDefaults($defaults) { $this->configDefaults = $this->processArray($defaults); return $this; } /** * Sets the required config options * * @param array|Collection $required The required config options * * @return ClientBuilder */ public function setConfigRequirements($required) { $this->configRequirements = $this->processArray($required); return $this; } /** * Sets the exception parser. If one is not provided the builder will use * the default XML exception parser. * * @param ExceptionParserInterface $parser The exception parser * * @return ClientBuilder */ public function setExceptionParser(ExceptionParserInterface $parser) { $this->exceptionParser = $parser; return $this; } /** * Set the configuration for the client's iterators * * @param array $config Configuration data for client's iterators * * @return ClientBuilder */ public function setIteratorsConfig(array $config) { $this->iteratorsConfig = $config; return $this; } /** * Performs the building logic using all of the parameters that have been * set and falling back to default values. Returns an instantiate service * client with credentials prepared and plugins attached. * * @return AwsClientInterface * @throws InvalidArgumentException */ public function build() { // Resolve configuration $config = Collection::fromConfig( $this->config, array_merge(self::$commonConfigDefaults, $this->configDefaults), (self::$commonConfigRequirements + $this->configRequirements) ); // Resolve endpoint and signature from the config and service description $description = $this->updateConfigFromDescription($config); $signature = $this->getSignature($description, $config); // Resolve credentials if (!$credentials = $config->get('credentials')) { $credentials = Credentials::factory($config); } // Resolve exception parser if (!$this->exceptionParser) { $this->exceptionParser = new DefaultXmlExceptionParser(); } // Resolve backoff strategy $backoff = $config->get(Options::BACKOFF); if ($backoff === null) { $backoff = new BackoffPlugin( // Retry failed requests up to 3 times if it is determined that the request can be retried new TruncatedBackoffStrategy(3, // Retry failed requests with 400-level responses due to throttling new ThrottlingErrorChecker($this->exceptionParser, // Retry failed requests with 500-level responses new HttpBackoffStrategy(array(500, 503, 509), // Retry failed requests due to transient network or cURL problems new CurlBackoffStrategy(null, // Retry requests that failed due to expired credentials new ExpiredCredentialsChecker($this->exceptionParser, new ExponentialBackoffStrategy() ) ) ) ) ) ); $config->set(Options::BACKOFF, $backoff); } if ($backoff) { $this->addBackoffLogger($backoff, $config); } // Determine service and class name $clientClass = 'Aws\Common\Client\DefaultClient'; if ($this->clientNamespace) { $serviceName = substr($this->clientNamespace, strrpos($this->clientNamespace, '\\') + 1); $clientClass = $this->clientNamespace . '\\' . $serviceName . 'Client'; } /** @var $client AwsClientInterface */ $client = new $clientClass($credentials, $signature, $config); $client->setDescription($description); // Add exception marshaling so that more descriptive exception are thrown if ($this->clientNamespace) { $exceptionFactory = new NamespaceExceptionFactory( $this->exceptionParser, "{$this->clientNamespace}\\Exception", "{$this->clientNamespace}\\Exception\\{$serviceName}Exception" ); $client->addSubscriber(new ExceptionListener($exceptionFactory)); } // Add the UserAgentPlugin to append to the User-Agent header of requests $client->addSubscriber(new UserAgentListener()); // Filters used for the cache plugin $client->getConfig()->set( 'params.cache.key_filter', 'header=date,x-amz-date,x-amz-security-token,x-amzn-authorization' ); // Set the iterator resource factory based on the provided iterators config $client->setResourceIteratorFactory(new AwsResourceIteratorFactory( $this->iteratorsConfig, new ResourceIteratorClassFactory($this->clientNamespace . '\\Iterator') )); // Disable parameter validation if needed if ($config->get(Options::VALIDATION) === false) { $params = $config->get('command.params') ?: array(); $params['command.disable_validation'] = true; $config->set('command.params', $params); } return $client; } /** * Add backoff logging to the backoff plugin if needed * * @param BackoffPlugin $plugin Backoff plugin * @param Collection $config Configuration settings * * @throws InvalidArgumentException */ protected function addBackoffLogger(BackoffPlugin $plugin, Collection $config) { // The log option can be set to `debug` or an instance of a LogAdapterInterface if ($logger = $config->get(Options::BACKOFF_LOGGER)) { $format = $config->get(Options::BACKOFF_LOGGER_TEMPLATE); if ($logger === 'debug') { $logger = new ClosureLogAdapter(function ($message) { trigger_error($message . "\n"); }); } elseif (!($logger instanceof LogAdapterInterface)) { throw new InvalidArgumentException( Options::BACKOFF_LOGGER . ' must be set to `debug` or an instance of ' . 'Guzzle\\Common\\Log\\LogAdapterInterface' ); } // Create the plugin responsible for logging exponential backoff retries $logPlugin = new BackoffLogger($logger); // You can specify a custom format or use the default if ($format) { $logPlugin->setTemplate($format); } $plugin->addSubscriber($logPlugin); } } /** * Ensures that an array (e.g. for config data) is actually in array form * * @param array|Collection $array The array data * * @return array * @throws InvalidArgumentException if the arg is not an array or Collection */ protected function processArray($array) { if ($array instanceof Collection) { $array = $array->getAll(); } if (!is_array($array)) { throw new InvalidArgumentException('The config must be provided as an array or Collection.'); } return $array; } /** * Update a configuration object from a service description * * @param Collection $config Config to update * * @return ServiceDescription * @throws InvalidArgumentException */ protected function updateConfigFromDescription(Collection $config) { $description = $config->get(Options::SERVICE_DESCRIPTION); if (!($description instanceof ServiceDescription)) { // Inject the version into the sprintf template if it is a string if (is_string($description)) { $description = sprintf($description, $config->get(Options::VERSION)); } $description = ServiceDescription::factory($description); $config->set(Options::SERVICE_DESCRIPTION, $description); } if (!$config->get(Options::SERVICE)) { $config->set(Options::SERVICE, $description->getData('endpointPrefix')); } if ($iterators = $description->getData('iterators')) { $this->setIteratorsConfig($iterators); } // Ensure that the service description has regions if (!$description->getData('regions')) { throw new InvalidArgumentException( 'No regions found in the ' . $description->getData('serviceFullName'). ' description' ); } // Make sure a valid region is set $region = $config->get(Options::REGION); $global = $description->getData('globalEndpoint'); if (!$global && !$region) { throw new InvalidArgumentException( 'A region is required when using ' . $description->getData('serviceFullName') . '. Set "region" to one of: ' . implode(', ', array_keys($description->getData('regions'))) ); } elseif ($global && (!$region || $description->getData('namespace') !== 'S3')) { $region = Region::US_EAST_1; $config->set(Options::REGION, $region); } if (!$config->get(Options::BASE_URL)) { // Set the base URL using the scheme and hostname of the service's region $config->set(Options::BASE_URL, AbstractClient::getEndpoint( $description, $region, $config->get(Options::SCHEME) )); } return $description; } /** * Return an appropriate signature object for a a client based on the * "signature" configuration setting, or the default signature specified in * a service description. The signature can be set to a valid signature * version identifier string or an instance of Aws\Common\Signature\SignatureInterface. * * @param ServiceDescription $description Description that holds a signature option * @param Collection $config Configuration options * * @return SignatureInterface * @throws InvalidArgumentException */ protected function getSignature(ServiceDescription $description, Collection $config) { // If a custom signature has not been provided, then use the default // signature setting specified in the service description. $signature = $config->get(Options::SIGNATURE) ?: $description->getData('signatureVersion'); if (is_string($signature)) { if ($signature == 'v4') { $signature = new SignatureV4(); } elseif ($signature == 'v2') { $signature = new SignatureV2(); } elseif ($signature == 'v3https') { $signature = new SignatureV3Https(); } else { throw new InvalidArgumentException("Invalid signature type: {$signature}"); } } elseif (!($signature instanceof SignatureInterface)) { throw new InvalidArgumentException('The provided signature is not ' . 'a signature version string or an instance of ' . 'Aws\\Common\\Signature\\SignatureInterface'); } // Allow a custom service name or region value to be provided if ($signature instanceof EndpointSignatureInterface) { // Determine the service name to use when signing $signature->setServiceName($config->get(Options::SIGNATURE_SERVICE) ?: $description->getData('signingName') ?: $description->getData('endpointPrefix')); // Determine the region to use when signing requests $signature->setRegionName($config->get(Options::SIGNATURE_REGION) ?: $config->get(Options::REGION)); } return $signature; } } sdk-2.5.2/Aws/Common/Client/DefaultClient.php000064411532700161006750000000670612272324172016053 0ustar setConfig($config) ->setConfigDefaults(array(Options::SCHEME => 'https')) ->build(); } } sdk-2.5.2/Aws/Common/Client/ExpiredCredentialsChecker.php000064411532700161006750000000522412272324172020365 0ustar true, 'ExpiredTokenException' => true, 'ExpiredToken' => true ); /** * @var ExceptionParserInterface Exception parser used to parse exception responses */ protected $exceptionParser; public function __construct(ExceptionParserInterface $exceptionParser, BackoffStrategyInterface $next = null) { $this->exceptionParser = $exceptionParser; $this->next = $next; } public function makesDecision() { return true; } protected function getDelay($retries, RequestInterface $request, Response $response = null, HttpException $e = null) { if ($response && $response->isClientError()) { $parts = $this->exceptionParser->parse($request, $response); if (!isset($this->retryable[$parts['code']]) || !$request->getClient()) { return null; } /** @var $client AwsClientInterface */ $client = $request->getClient(); // Only retry if the credentials can be refreshed if (!($client->getCredentials() instanceof AbstractRefreshableCredentials)) { return null; } // Resign the request using new credentials $client->getSignature()->signRequest($request, $client->getCredentials()->setExpiration(-1)); // Retry immediately with no delay return 0; } } } sdk-2.5.2/Aws/Common/Client/ThrottlingErrorChecker.php000064411532700161006750000000453212272324172017760 0ustar true, 'Throttling' => true, 'ThrottlingException' => true, 'ProvisionedThroughputExceededException' => true, 'RequestThrottled' => true, ); /** * @var ExceptionParserInterface Exception parser used to parse exception responses */ protected $exceptionParser; public function __construct(ExceptionParserInterface $exceptionParser, BackoffStrategyInterface $next = null) { $this->exceptionParser = $exceptionParser; if ($next) { $this->setNext($next); } } /** * {@inheritdoc} */ public function makesDecision() { return true; } /** * {@inheritdoc} */ protected function getDelay( $retries, RequestInterface $request, Response $response = null, HttpException $e = null ) { if ($response && $response->isClientError()) { $parts = $this->exceptionParser->parse($request, $response); return isset(self::$throttlingExceptions[$parts['code']]) ? true : null; } } } sdk-2.5.2/Aws/Common/Client/UploadBodyListener.php000064411532700161006750000000647312272324172017101 0ustar commands = $commands; $this->bodyParameter = (string) $bodyParameter; $this->sourceParameter = (string) $sourceParameter; } /** * {@inheritdoc} */ public static function getSubscribedEvents() { return array('command.before_prepare' => array('onCommandBeforePrepare')); } /** * Converts filenames and file handles into EntityBody objects before the command is validated * * @param Event $event Event emitted * @throws InvalidArgumentException */ public function onCommandBeforePrepare(Event $event) { /** @var $command Command */ $command = $event['command']; if (in_array($command->getName(), $this->commands)) { // Get the interesting parameters $source = $command->get($this->sourceParameter); $body = $command->get($this->bodyParameter); // If a file path is passed in then get the file handle if (is_string($source) && file_exists($source)) { $body = fopen($source, 'r'); } // Prepare the body parameter and remove the source file parameter if (null !== $body) { $command->remove($this->sourceParameter); $command->set($this->bodyParameter, EntityBody::factory($body)); } else { throw new InvalidArgumentException("You must specify a non-null value for the {$this->bodyParameter} or {$this->sourceParameter} parameters."); } } } } sdk-2.5.2/Aws/Common/Client/UserAgentListener.php000064411532700161006750000000364312272324172016730 0ustar 'onBeforeSend'); } /** * Adds strings to the User-Agent header using the `ua.append` parameter of a command * * @param Event $event Event emitted */ public function onBeforeSend(Event $event) { $command = $event['command']; if ($userAgentAppends = $command->get(self::OPTION)) { $request = $command->getRequest(); $userAgent = (string) $request->getHeader('User-Agent'); foreach ((array) $userAgentAppends as $append) { $append = ' ' . $append; if (strpos($userAgent, $append) === false) { $userAgent .= $append; } } $request->setHeader('User-Agent', $userAgent); } } } sdk-2.5.2/Aws/Common/Command/AwsQueryVisitor.php000064411532700161006750000000777412272324172016636 0ustar customResolver($value, $param, $query, $param->getWireName()); $request->addPostFields($query); } /** * Map nested parameters into the location_key based parameters * * @param array $value Value to map * @param Parameter $param Parameter that holds information about the current key * @param array $query Built up query string values * @param string $prefix String to prepend to sub query values */ protected function customResolver($value, Parameter $param, array &$query, $prefix = '') { switch ($param->getType()) { case 'object': $this->resolveObject($param, $value, $prefix, $query); break; case 'array': $this->resolveArray($param, $value, $prefix, $query); break; default: $query[$prefix] = $param->filter($value); } } /** * Custom handling for objects * * @param Parameter $param Parameter for the object * @param array $value Value that is set for this parameter * @param string $prefix Prefix for the resulting key * @param array $query Query string array passed by reference */ protected function resolveObject(Parameter $param, array $value, $prefix, array &$query) { // Maps are implemented using additional properties $hasAdditionalProperties = ($param->getAdditionalProperties() instanceof Parameter); $additionalPropertyCount = 0; foreach ($value as $name => $v) { if ($subParam = $param->getProperty($name)) { // if the parameter was found by name as a regular property $key = $prefix . '.' . $subParam->getWireName(); $this->customResolver($v, $subParam, $query, $key); } elseif ($hasAdditionalProperties) { // Handle map cases like &Attribute.1.Name=&Attribute.1.Value= $additionalPropertyCount++; $data = $param->getData(); $keyName = isset($data['keyName']) ? $data['keyName'] : 'key'; $valueName = isset($data['valueName']) ? $data['valueName'] : 'value'; $query["{$prefix}.{$additionalPropertyCount}.{$keyName}"] = $name; $newPrefix = "{$prefix}.{$additionalPropertyCount}.{$valueName}"; if (is_array($v)) { $this->customResolver($v, $param->getAdditionalProperties(), $query, $newPrefix); } else { $query[$newPrefix] = $param->filter($v); } } } } /** * Custom handling for arrays * * @param Parameter $param Parameter for the object * @param array $value Value that is set for this parameter * @param string $prefix Prefix for the resulting key * @param array $query Query string array passed by reference */ protected function resolveArray(Parameter $param, array $value, $prefix, array &$query) { $offset = $param->getData('offset') ?: 1; foreach ($value as $index => $v) { $index += $offset; if (is_array($v) && $items = $param->getItems()) { $this->customResolver($v, $items, $query, $prefix . '.' . $index); } else { $query[$prefix . '.' . $index] = $param->filter($v); } } } } sdk-2.5.2/Aws/Common/Command/JsonCommand.php000064411532700161006750000000312512272324172015670 0ustar request->getBody()) { $this->request->setBody('{}'); } // Never send the Expect header when interacting with a JSON query service $this->request->removeHeader('Expect'); // Always send JSON requests as a raw string rather than using streams to avoid issues with // cURL error code 65: "necessary data rewind wasn't possible". // This could be removed after PHP addresses https://bugs.php.net/bug.php?id=47204 $this->request->getCurlOptions()->set(CurlHandle::BODY_AS_STRING, true); } } sdk-2.5.2/Aws/Common/Command/QueryCommand.php000064411532700161006750000000270312272324172016065 0ustar getRequestSerializer()->addVisitor('aws.query', self::$queryVisitor); $this->getResponseParser()->addVisitor('xml', self::$xmlVisitor); } } sdk-2.5.2/Aws/Common/Command/XmlResponseLocationVisitor.php000064411532700161006750000000414312272324172021011 0ustar getOperation(); if ($operation->getServiceDescription()->getData('resultWrapped')) { $wrappingNode = $operation->getName() . 'Result'; if (isset($result[$wrappingNode])) { $result = $result[$wrappingNode] + $result; unset($result[$wrappingNode]); } } } /** * Accounts for wrapper nodes * {@inheritdoc} */ public function visit( CommandInterface $command, Response $response, Parameter $param, &$value, $context = null ) { parent::visit($command, $response, $param, $value, $context); // Account for wrapper nodes (e.g. RDS, ElastiCache, etc) if ($param->getData('wrapper')) { $wireName = $param->getWireName(); $value += $value[$wireName]; unset($value[$wireName]); } } /** * Filter used when converting XML maps into associative arrays in service descriptions * * @param array $value Value to filter * @param string $entryName Name of each entry * @param string $keyName Name of each key * @param string $valueName Name of each value * * @return array Returns the map of the XML data */ public static function xmlMap($value, $entryName, $keyName, $valueName) { $result = array(); foreach ($value as $entry) { $result[$entry[$keyName]] = $entry[$valueName]; } return $result; } } sdk-2.5.2/Aws/Common/Credentials/AbstractCredentialsDecorator.php000064411532700161006750000000543712272324172022133 0ustar credentials = $credentials; } /** * {@inheritdoc} */ public function serialize() { return $this->credentials->serialize(); } /** * {@inheritdoc} */ public function unserialize($serialized) { $this->credentials = new Credentials('', ''); $this->credentials->unserialize($serialized); } /** * {@inheritdoc} */ public function getAccessKeyId() { return $this->credentials->getAccessKeyId(); } /** * {@inheritdoc} */ public function getSecretKey() { return $this->credentials->getSecretKey(); } /** * {@inheritdoc} */ public function getSecurityToken() { return $this->credentials->getSecurityToken(); } /** * {@inheritdoc} */ public function getExpiration() { return $this->credentials->getExpiration(); } /** * {@inheritdoc} */ public function isExpired() { return $this->credentials->isExpired(); } /** * {@inheritdoc} */ public function setAccessKeyId($key) { $this->credentials->setAccessKeyId($key); return $this; } /** * {@inheritdoc} */ public function setSecretKey($secret) { $this->credentials->setSecretKey($secret); return $this; } /** * {@inheritdoc} */ public function setSecurityToken($token) { $this->credentials->setSecurityToken($token); return $this; } /** * {@inheritdoc} */ public function setExpiration($timestamp) { $this->credentials->setExpiration($timestamp); return $this; } } sdk-2.5.2/Aws/Common/Credentials/AbstractRefreshableCredentials.php000064411532700161006750000000340312272324172022422 0ustar credentials->isExpired()) { $this->refresh(); } return $this->credentials->getAccessKeyId(); } /** * {@inheritdoc} */ public function getSecretKey() { if ($this->credentials->isExpired()) { $this->refresh(); } return $this->credentials->getSecretKey(); } /** * {@inheritdoc} */ public function getSecurityToken() { if ($this->credentials->isExpired()) { $this->refresh(); } return $this->credentials->getSecurityToken(); } /** * {@inheritdoc} */ public function serialize() { if ($this->credentials->isExpired()) { $this->refresh(); } return $this->credentials->serialize(); } /** * Attempt to get new credentials */ abstract protected function refresh(); } sdk-2.5.2/Aws/Common/Credentials/CacheableCredentials.php000064411532700161006750000000520012272324172020340 0ustar credentials = $credentials; $this->cache = $cache; $this->cacheKey = $cacheKey; } /** * Attempt to get new credentials from cache or from the adapted object */ protected function refresh() { if (!$cache = $this->cache->fetch($this->cacheKey)) { // The credentials were not found, so try again and cache if new $this->credentials->getAccessKeyId(); if (!$this->credentials->isExpired()) { // The credentials were updated, so cache them $this->cache->save($this->cacheKey, $this->credentials, $this->credentials->getExpiration() - time()); } } else { // The credentials were found in cache, so update the adapter object // if the cached credentials are not expired if (!$cache->isExpired()) { $this->credentials->setAccessKeyId($cache->getAccessKeyId()); $this->credentials->setSecretKey($cache->getSecretKey()); $this->credentials->setSecurityToken($cache->getSecurityToken()); $this->credentials->setExpiration($cache->getExpiration()); } } } } sdk-2.5.2/Aws/Common/Credentials/Credentials.php000064411532700161006750000002052412272324172016576 0ustar null, Options::SECRET => null, Options::TOKEN => null, Options::TOKEN_TTD => null, Options::CREDENTIALS_CACHE => null, Options::CREDENTIALS_CACHE_KEY => null, Options::CREDENTIALS_CLIENT => null ); } /** * Factory method for creating new credentials. This factory method will * create the appropriate credentials object with appropriate decorators * based on the passed configuration options. * * @param array $config Options to use when instantiating the credentials * * @return CredentialsInterface * @throws InvalidArgumentException If the caching options are invalid * @throws RuntimeException If using the default cache and APC is disabled */ public static function factory($config = array()) { // Add default key values foreach (self::getConfigDefaults() as $key => $value) { if (!isset($config[$key])) { $config[$key] = $value; } } // Start tracking the cache key $cacheKey = $config[Options::CREDENTIALS_CACHE_KEY]; // Create the credentials object if (!$config[Options::KEY] || !$config[Options::SECRET]) { // No keys were provided, so attempt to retrieve some from the environment $envKey = isset($_SERVER[self::ENV_KEY]) ? $_SERVER[self::ENV_KEY] : getenv(self::ENV_KEY); $envSecret = isset($_SERVER[self::ENV_SECRET]) ? $_SERVER[self::ENV_SECRET] : getenv(self::ENV_SECRET); if ($envKey && $envSecret) { // Use credentials set in the environment variables $credentials = new static($envKey, $envSecret); } else { // Use instance profile credentials (available on EC2 instances) $credentials = new RefreshableInstanceProfileCredentials( new static('', '', '', 1), $config[Options::CREDENTIALS_CLIENT] ); } // If no cache key was set, use the crc32 hostname of the server $cacheKey = $cacheKey ?: 'credentials_' . crc32(gethostname()); } else { // Instantiate using short or long term credentials $credentials = new static( $config[Options::KEY], $config[Options::SECRET], $config[Options::TOKEN], $config[Options::TOKEN_TTD] ); // If no cache key was set, use the access key ID $cacheKey = $cacheKey ?: 'credentials_' . $config[Options::KEY]; } // Check if the credentials are refreshable, and if so, configure caching $cache = $config[Options::CREDENTIALS_CACHE]; if ($cacheKey && $cache) { if ($cache === 'true' || $cache === true) { // If no cache adapter was provided, then create one for the user // @codeCoverageIgnoreStart if (!extension_loaded('apc')) { throw new RequiredExtensionNotLoadedException('PHP has not been compiled with APC. Unable to cache ' . 'the credentials.'); } elseif (!class_exists('Doctrine\Common\Cache\ApcCache')) { throw new RuntimeException( 'Cannot set ' . Options::CREDENTIALS_CACHE . ' to true because the Doctrine cache component is ' . 'not installed. Either install doctrine/cache or pass in an instantiated ' . 'Guzzle\Cache\CacheAdapterInterface object' ); } // @codeCoverageIgnoreEnd $cache = new DoctrineCacheAdapter(new \Doctrine\Common\Cache\ApcCache()); } elseif (!($cache instanceof CacheAdapterInterface)) { throw new InvalidArgumentException('Unable to utilize caching with the specified options'); } // Decorate the credentials with a cache $credentials = new CacheableCredentials($credentials, $cache, $cacheKey); } return $credentials; } /** * Constructs a new BasicAWSCredentials object, with the specified AWS * access key and AWS secret key * * @param string $accessKeyId AWS access key ID * @param string $secretAccessKey AWS secret access key * @param string $token Security token to use * @param int $expiration UNIX timestamp for when credentials expire */ public function __construct($accessKeyId, $secretAccessKey, $token = null, $expiration = null) { $this->key = trim($accessKeyId); $this->secret = trim($secretAccessKey); $this->token = $token; $this->ttd = $expiration; } /** * {@inheritdoc} */ public function serialize() { return json_encode(array( Options::KEY => $this->key, Options::SECRET => $this->secret, Options::TOKEN => $this->token, Options::TOKEN_TTD => $this->ttd )); } /** * {@inheritdoc} */ public function unserialize($serialized) { $data = json_decode($serialized, true); $this->key = $data[Options::KEY]; $this->secret = $data[Options::SECRET]; $this->token = $data[Options::TOKEN]; $this->ttd = $data[Options::TOKEN_TTD]; } /** * {@inheritdoc} */ public function getAccessKeyId() { return $this->key; } /** * {@inheritdoc} */ public function getSecretKey() { return $this->secret; } /** * {@inheritdoc} */ public function getSecurityToken() { return $this->token; } /** * {@inheritdoc} */ public function getExpiration() { return $this->ttd; } /** * {@inheritdoc} */ public function isExpired() { return $this->ttd !== null && time() >= $this->ttd; } /** * {@inheritdoc} */ public function setAccessKeyId($key) { $this->key = $key; return $this; } /** * {@inheritdoc} */ public function setSecretKey($secret) { $this->secret = $secret; return $this; } /** * {@inheritdoc} */ public function setSecurityToken($token) { $this->token = $token; return $this; } /** * {@inheritdoc} */ public function setExpiration($timestamp) { $this->ttd = $timestamp; return $this; } } sdk-2.5.2/Aws/Common/Credentials/CredentialsInterface.php000064411532700161006750000000465012272324172020421 0ustar credentials = $credentials; $this->client = $client ?: InstanceMetadataClient::factory(); } /** * Attempt to get new credentials from the instance profile * * @throws InstanceProfileCredentialsException On error */ protected function refresh() { $credentials = $this->client->getInstanceProfileCredentials(); // Expire the token 1 minute before it actually expires to pre-fetch before expiring $this->credentials->setAccessKeyId($credentials->getAccessKeyId()) ->setSecretKey($credentials->getSecretKey()) ->setSecurityToken($credentials->getSecurityToken()) ->setExpiration($credentials->getExpiration()); } } sdk-2.5.2/Aws/Common/Enum/ClientOptions.php000064411532700161006750000001060312272324172015577 0ustar factory = $factory; } /** * {@inheritdoc} */ public static function getSubscribedEvents() { return array('request.error' => array('onRequestError', -1)); } /** * Throws a more meaningful request exception if available * * @param Event $event Event emitted */ public function onRequestError(Event $event) { $e = $this->factory->fromResponse($event['request'], $event['response']); $event->stopPropagation(); throw $e; } } sdk-2.5.2/Aws/Common/Exception/InstanceProfileCredentialsException.php000064411532700161006750000000241612272324172023164 0ustar statusCode = $code; } /** * Get the error response code from the service * * @return string|null */ public function getStatusCode() { return $this->statusCode; } } sdk-2.5.2/Aws/Common/Exception/InvalidArgumentException.php000064411532700161006750000000144112272324172021007 0ustar getMessage(), 0, $exception ); $this->state = $state; } /** * Get the state of the transfer * * @return TransferStateInterface */ public function getState() { return $this->state; } } sdk-2.5.2/Aws/Common/Exception/NamespaceExceptionFactory.php000064411532700161006750000000677112272324172021155 0ustar parser = $parser; $this->baseNamespace = $baseNamespace; $this->defaultException = $defaultException; } /** * {@inheritdoc} */ public function fromResponse(RequestInterface $request, Response $response) { $parts = $this->parser->parse($request, $response); // Removing leading 'AWS.' and embedded periods $className = $this->baseNamespace . '\\' . str_replace(array('AWS.', '.'), '', $parts['code']); if (substr($className, -9) !== 'Exception') { $className .= 'Exception'; } $className = class_exists($className) ? $className : $this->defaultException; return $this->createException($className, $request, $response, $parts); } /** * Create an prepare an exception object * * @param string $className Name of the class to create * @param RequestInterface $request Request * @param Response $response Response received * @param array $parts Parsed exception data * * @return \Exception */ protected function createException($className, RequestInterface $request, Response $response, array $parts) { $class = new $className($parts['message']); if ($class instanceof ServiceResponseException) { $class->setExceptionCode($parts['code']); $class->setExceptionType($parts['type']); $class->setResponse($response); $class->setRequest($request); $class->setRequestId($parts['request_id']); } return $class; } } sdk-2.5.2/Aws/Common/Exception/OutOfBoundsException.php000064411532700161006750000000142212272324172020124 0ustar exceptionCode = $code; } /** * Get the exception code * * @return string|null */ public function getExceptionCode() { return $this->exceptionCode; } /** * Set the exception type * * @param string $type Exception type */ public function setExceptionType($type) { $this->exceptionType = $type; } /** * Get the exception type (one of client or server) * * @return string|null */ public function getExceptionType() { return $this->exceptionType; } /** * Set the request ID * * @param string $id Request ID */ public function setRequestId($id) { $this->requestId = $id; } /** * Get the Request ID * * @return string|null */ public function getRequestId() { return $this->requestId; } /** * Set the associated response * * @param Response $response Response */ public function setResponse(Response $response) { $this->response = $response; } /** * Get the associated response object * * @return Response|null */ public function getResponse() { return $this->response; } /** * Set the associated request * * @param RequestInterface $request */ public function setRequest(RequestInterface $request) { $this->request = $request; } /** * Get the associated request object * * @return RequestInterface|null */ public function getRequest() { return $this->request; } /** * Get the status code of the response * * @return int|null */ public function getStatusCode() { return $this->response ? $this->response->getStatusCode() : null; } /** * Cast to a string * * @return string */ public function __toString() { $message = get_class($this) . ': ' . 'AWS Error Code: ' . $this->getExceptionCode() . ', ' . 'Status Code: ' . $this->getStatusCode() . ', ' . 'AWS Request ID: ' . $this->getRequestId() . ', ' . 'AWS Error Type: ' . $this->getExceptionType() . ', ' . 'AWS Error Message: ' . $this->getMessage(); // Add the User-Agent if available if ($this->request) { $message .= ', ' . 'User-Agent: ' . $this->request->getHeader('User-Agent'); } return $message; } } sdk-2.5.2/Aws/Common/Exception/TransferException.php000064411532700161006750000000142312272324172017502 0ustar null, 'message' => null, 'type' => $response->isClientError() ? 'client' : 'server', 'request_id' => (string) $response->getHeader('x-amzn-RequestId'), 'parsed' => null ); // Parse the json and normalize key casings if (null !== $json = json_decode($response->getBody(true), true)) { $data['parsed'] = array_change_key_case($json); } // Do additional, protocol-specific parsing and return the result $data = $this->doParse($data, $response); // Remove "Fault" suffix from exception names if (isset($data['code']) && strpos($data['code'], 'Fault')) { $data['code'] = preg_replace('/^([a-zA-Z]+)Fault$/', '$1', $data['code']); } return $data; } /** * Pull relevant exception data out of the parsed json * * @param array $data The exception data * @param Response $response The response from the service containing the error * * @return array */ abstract protected function doParse(array $data, Response $response); } sdk-2.5.2/Aws/Common/Exception/Parser/DefaultXmlExceptionParser.php000064411532700161006750000000637212272324172022404 0ustar null, 'message' => null, 'type' => $response->isClientError() ? 'client' : 'server', 'request_id' => null, 'parsed' => null ); if ($body = $response->getBody(true)) { $this->parseBody(new \SimpleXMLElement($body), $data); } else { $this->parseHeaders($request, $response, $data); } return $data; } /** * Parses additional exception information from the response headers * * @param RequestInterface $request Request that was issued * @param Response $response The response from the request * @param array $data The current set of exception data */ protected function parseHeaders(RequestInterface $request, Response $response, array &$data) { $data['message'] = $response->getStatusCode() . ' ' . $response->getReasonPhrase(); if ($requestId = $response->getHeader('x-amz-request-id')) { $data['request_id'] = $requestId; $data['message'] .= " (Request-ID: $requestId)"; } } /** * Parses additional exception information from the response body * * @param \SimpleXMLElement $body The response body as XML * @param array $data The current set of exception data */ protected function parseBody(\SimpleXMLElement $body, array &$data) { $data['parsed'] = $body; $namespaces = $body->getDocNamespaces(); if (isset($namespaces[''])) { // Account for the default namespace being defined and PHP not being able to handle it :( $body->registerXPathNamespace('ns', $namespaces['']); $prefix = 'ns:'; } else { $prefix = ''; } if ($tempXml = $body->xpath("//{$prefix}Code[1]")) { $data['code'] = (string) $tempXml[0]; } if ($tempXml = $body->xpath("//{$prefix}Message[1]")) { $data['message'] = (string) $tempXml[0]; } $tempXml = $body->xpath("//{$prefix}RequestId[1]"); if (empty($tempXml)) { $tempXml = $body->xpath("//{$prefix}RequestID[1]"); } if (isset($tempXml[0])) { $data['request_id'] = (string) $tempXml[0]; } } } sdk-2.5.2/Aws/Common/Exception/Parser/ExceptionParserInterface.php000064411532700161006750000000256112272324172022233 0ustar getHeader('x-amzn-ErrorType')) { $data['code'] = substr($code, 0, strpos($code, ':')); } return $data; } } sdk-2.5.2/Aws/Common/Facade/facade-classes.php000064411532700161006750000001160012272324172016100 0ustar getConfig() as $service) { if (isset($service['alias'], $service['class'])) { $facadeClass = __NAMESPACE__ . '\\' . $service['alias']; $facadeAlias = ltrim($targetNamespace . '\\' . $service['alias'], '\\'); if (!class_exists($facadeAlias)) { // @codeCoverageIgnoreStart class_alias($facadeClass, $facadeAlias); // @codeCoverageIgnoreEnd } } } } /** * Returns the instance of the client that the facade operates on * * @return \Aws\Common\Client\AwsClientInterface */ public static function getClient() { return self::$serviceBuilder->get(static::getServiceBuilderKey()); } public static function __callStatic($method, $args) { return call_user_func_array(array(self::getClient(), $method), $args); } } sdk-2.5.2/Aws/Common/Facade/FacadeInterface.php000064411532700161006750000000211412272324172016226 0ustar context = hash_init($algorithm); } /** * {@inheritdoc} */ public function addData($data) { if (!$this->context) { throw new LogicException('You may not add more data to a finalized chunk hash.'); } hash_update($this->context, $data); return $this; } /** * {@inheritdoc} */ public function getHash($returnBinaryForm = false) { if (!$this->hash) { $this->hashRaw = hash_final($this->context, true); $this->hash = HashUtils::binToHex($this->hashRaw); $this->context = null; } return $returnBinaryForm ? $this->hashRaw : $this->hash; } /** * {@inheritdoc} */ public function __clone() { if ($this->context) { $this->context = hash_copy($this->context); } } } sdk-2.5.2/Aws/Common/Hash/ChunkHashInterface.php000064411532700161006750000000271412272324172016465 0ustar checksums = $inBinaryForm ? $checksums : array_map('Aws\Common\Hash\HashUtils::hexToBin', $checksums); // Pre-calculate hash $treeHash->getHash(); return $treeHash; } /** * Create a tree hash from a content body * * @param string|resource|EntityBody $content Content to create a tree hash for * @param string $algorithm A valid hash algorithm name as returned by `hash_algos()` * * @return TreeHash */ public static function fromContent($content, $algorithm = self::DEFAULT_ALGORITHM) { $treeHash = new self($algorithm); // Read the data in 1MB chunks and add to tree hash $content = EntityBody::factory($content); while ($data = $content->read(Size::MB)) { $treeHash->addData($data); } // Pre-calculate hash $treeHash->getHash(); return $treeHash; } /** * Validates an entity body with a tree hash checksum * * @param string|resource|EntityBody $content Content to create a tree hash for * @param string $checksum The checksum to use for validation * @param string $algorithm A valid hash algorithm name as returned by `hash_algos()` * * @return bool */ public static function validateChecksum($content, $checksum, $algorithm = self::DEFAULT_ALGORITHM) { $treeHash = self::fromContent($content, $algorithm); return ($checksum === $treeHash->getHash()); } /** * {@inheritdoc} */ public function __construct($algorithm = self::DEFAULT_ALGORITHM) { HashUtils::validateAlgorithm($algorithm); $this->algorithm = $algorithm; } /** * {@inheritdoc} * @throws LogicException if the root tree hash is already calculated * @throws InvalidArgumentException if the data is larger than 1MB */ public function addData($data) { // Error if hash is already calculated if ($this->hash) { throw new LogicException('You may not add more data to a finalized tree hash.'); } // Make sure that only 1MB chunks or smaller get passed in if (strlen($data) > Size::MB) { throw new InvalidArgumentException('The chunk of data added is too large for tree hashing.'); } // Store the raw hash of this data segment $this->checksums[] = hash($this->algorithm, $data, true); return $this; } /** * Add a checksum to the tree hash directly * * @param string $checksum The checksum to add * @param bool $inBinaryForm Whether or not the checksum is already in binary form * * @return self * @throws LogicException if the root tree hash is already calculated */ public function addChecksum($checksum, $inBinaryForm = false) { // Error if hash is already calculated if ($this->hash) { throw new LogicException('You may not add more checksums to a finalized tree hash.'); } // Convert the checksum to binary form if necessary $this->checksums[] = $inBinaryForm ? $checksum : HashUtils::hexToBin($checksum); return $this; } /** * {@inheritdoc} */ public function getHash($returnBinaryForm = false) { if (!$this->hash) { // Perform hashes up the tree to arrive at the root checksum of the tree hash $hashes = $this->checksums; while (count($hashes) > 1) { $sets = array_chunk($hashes, 2); $hashes = array(); foreach ($sets as $set) { $hashes[] = (count($set) === 1) ? $set[0] : hash($this->algorithm, $set[0] . $set[1], true); } } $this->hashRaw = $hashes[0]; $this->hash = HashUtils::binToHex($this->hashRaw); } return $returnBinaryForm ? $this->hashRaw : $this->hash; } /** * @return array Array of raw checksums composing the tree hash */ public function getChecksums() { return $this->checksums; } } sdk-2.5.2/Aws/Common/InstanceMetadata/InstanceMetadataClient.php000064411532700161006750000000727312272324172021663 0ustar 'http://169.254.169.254/{version}/', 'version' => 'latest', 'request.options' => array( 'connect_timeout' => 5, 'timeout' => 10 ) ), array('base_url', 'version')); return new self($config); } /** * Constructor override */ public function __construct(Collection $config) { $this->setConfig($config); $this->setBaseUrl($config->get(Options::BASE_URL)); $this->defaultHeaders = new Collection(); $this->setRequestFactory(RequestFactory::getInstance()); } /** * Get instance profile credentials * * @return Credentials * @throws InstanceProfileCredentialsException */ public function getInstanceProfileCredentials() { try { $request = $this->get('meta-data/iam/security-credentials/'); $credentials = trim($request->send()->getBody(true)); $result = $this->get("meta-data/iam/security-credentials/{$credentials}")->send()->json(); } catch (\Exception $e) { $message = sprintf('Error retrieving credentials from the instance profile metadata server. When you are' . ' not running inside of Amazon EC2, you must provide your AWS access key ID and secret access key in' . ' the "key" and "secret" options when creating a client or provide an instantiated' . ' Aws\\Common\\Credentials\\CredentialsInterface object. (%s)', $e->getMessage()); throw new InstanceProfileCredentialsException($message, $e->getCode()); } // Ensure that the status code was successful if ($result['Code'] !== 'Success') { $e = new InstanceProfileCredentialsException('Unexpected response code: ' . $result['Code']); $e->setStatusCode($result['Code']); throw $e; } return new Credentials( $result['AccessKeyId'], $result['SecretAccessKey'], $result['Token'], strtotime($result['Expiration']) ); } } sdk-2.5.2/Aws/Common/InstanceMetadata/Waiter/ServiceAvailable.php000064411532700161006750000000270312272324172021744 0ustar client->get(); try { $request->getCurlOptions()->set(CURLOPT_CONNECTTIMEOUT, 10) ->set(CURLOPT_TIMEOUT, 10); $request->send(); return true; } catch (CurlException $e) { return false; } } } sdk-2.5.2/Aws/Common/Iterator/AwsResourceIterator.php000064411532700161006750000001163312272324172017652 0ustar lastResult; } /** * {@inheritdoc} * This AWS specific version of the resource iterator provides a default implementation of the typical AWS iterator * process. It relies on configuration and extension to implement the operation-specific logic of handling results * and nextTokens. This method will loop until resources are acquired or there are no more iterations available. */ protected function sendRequest() { do { // Prepare the request including setting the next token $this->prepareRequest(); if ($this->nextToken) { $this->applyNextToken(); } // Execute the request and handle the results $this->command->add(Ua::OPTION, Ua::ITERATOR); $this->lastResult = $this->command->getResult(); $resources = $this->handleResults($this->lastResult); $this->determineNextToken($this->lastResult); // If no resources collected, prepare to reiterate before yielding if ($reiterate = empty($resources) && $this->nextToken) { $this->command = clone $this->originalCommand; } } while ($reiterate); return $resources; } /** * {@inheritdoc} */ protected function prepareRequest() { // Get the limit parameter key to set $param = $this->get('limit_param'); if ($param && ($limit = $this->command->get($param))) { $pageSize = $this->calculatePageSize(); // If the limit of the command is different than the pageSize of the iterator, use the smaller value if ($limit && $pageSize) { $this->command->set('limit', min($limit, $pageSize)); } } } /** * {@inheritdoc} */ protected function handleResults(Model $result) { $results = array(); // Get the result key that contains the results if ($resultKey = $this->get('result_key')) { $results = $result->getPath($resultKey) ?: array(); } return $results; } /** * {@inheritdoc} */ protected function applyNextToken() { // Get the token parameter key to set if ($tokenParam = $this->get('token_param')) { // Set the next token. Works with multi-value tokens if (is_array($tokenParam)) { if (is_array($this->nextToken) && count($tokenParam) === count($this->nextToken)) { foreach (array_combine($tokenParam, $this->nextToken) as $param => $token) { $this->command->set($param, $token); } } else { throw new RuntimeException('The definition of the iterator\'s token parameter and the actual token ' . 'value are not compatible.'); } } else { $this->command->set($tokenParam, $this->nextToken); } } } /** * {@inheritdoc} */ protected function determineNextToken(Model $result) { $this->nextToken = null; // If the value of "more key" is true or there is no "more key" to check, then try to get the next token $moreKey = $this->get('more_key'); if ($moreKey === null || $result->getPath($moreKey)) { // Get the token key to check if ($tokenKey = $this->get('token_key')) { // Get the next token's value. Works with multi-value tokens $getToken = function ($key) use ($result) { return $result->getPath((string) $key); }; $this->nextToken = is_array($tokenKey) ? array_map($getToken, $tokenKey) : $getToken($tokenKey); } } } } sdk-2.5.2/Aws/Common/Iterator/AwsResourceIteratorFactory.php000064411532700161006750000000725412272324172021206 0ustar null, 'limit_param' => null, 'more_key' => null, 'token_key' => null, 'token_param' => null, 'operations' => array(), ); /** * @var Collection The configuration for the iterators */ protected $config; /** * @var Collection Additional configurations for specific iterators */ protected $operations; /** * @var ResourceIteratorFactoryInterface Another factory that will be used first to instantiate the iterator */ protected $primaryIteratorFactory; /** * @param array $config An array of configuration values for the factory * @param ResourceIteratorFactoryInterface $primaryIteratorFactory Another factory to use for chain of command * * @throws InvalidArgumentException */ public function __construct(array $config, ResourceIteratorFactoryInterface $primaryIteratorFactory = null) { $this->primaryIteratorFactory = $primaryIteratorFactory; // Set up the config with default values $this->config = Collection::fromConfig($config, self::$defaultConfig); // Pull out the operation-specific configurations $this->operations = new Collection(); $potentialOperations = $this->config->get('operations') ?: array(); $this->config->remove('operations'); foreach ($potentialOperations as $key => $value) { if (is_int($key) && is_string($value)) { $this->operations->set($value, array()); } elseif (is_string($key) && is_array($value)) { $this->operations->set($key, $value); } else { throw new InvalidArgumentException('The iterator factory configuration was invalid.'); } } } /** * {@inheritdoc} */ public function build(CommandInterface $command, array $options = array()) { // Get the configuration data for the command $commandName = $command->getName(); $iteratorConfig = $this->operations->get($commandName) ?: array(); $options = array_replace($this->config->getAll(), $iteratorConfig, $options); // Instantiate the iterator using the primary factory (if there is one) if ($this->primaryIteratorFactory && $this->primaryIteratorFactory->canBuild($command)) { $iterator = $this->primaryIteratorFactory->build($command, $options); } elseif (!$this->operations->hasKey($commandName)) { throw new InvalidArgumentException("Iterator was not found for {$commandName}."); } else { // Fallback to this factory for creating the iterator if the primary factory did not work $iterator = new AwsResourceIterator($command, $options); } return $iterator; } /** * {@inheritdoc} */ public function canBuild(CommandInterface $command) { return ($this->primaryIteratorFactory && $this->primaryIteratorFactory->canBuild($command)) || $this->operations->hasKey($command->getName()); } } sdk-2.5.2/Aws/Common/Model/MultipartUpload/AbstractTransfer.php000064411532700161006750000001547512272324172021553 0ustar client = $client; $this->state = $state; $this->source = $source; $this->options = $options; $this->init(); $this->partSize = $this->calculatePartSize(); } public function __invoke() { return $this->upload(); } /** * {@inheritdoc} */ public static function getAllEvents() { return array( self::BEFORE_PART_UPLOAD, self::AFTER_UPLOAD, self::BEFORE_PART_UPLOAD, self::AFTER_PART_UPLOAD, self::AFTER_ABORT, self::AFTER_COMPLETE ); } /** * {@inheritdoc} */ public function abort() { $command = $this->getAbortCommand(); $result = $command->getResult(); $this->state->setAborted(true); $this->stop(); $this->dispatch(self::AFTER_ABORT, $this->getEventData($command)); return $result; } /** * {@inheritdoc} */ public function stop() { $this->stopped = true; return $this->state; } /** * {@inheritdoc} */ public function getState() { return $this->state; } /** * Get the array of options associated with the transfer * * @return array */ public function getOptions() { return $this->options; } /** * Set an option on the transfer * * @param string $option Name of the option * @param mixed $value Value to set * * @return self */ public function setOption($option, $value) { $this->options[$option] = $value; return $this; } /** * Get the source body of the upload * * @return EntityBodyInterface */ public function getSource() { return $this->source; } /** * {@inheritdoc} * @throws MultipartUploadException when an error is encountered. Use getLastException() to get more information. * @throws RuntimeException when attempting to upload an aborted transfer */ public function upload() { if ($this->state->isAborted()) { throw new RuntimeException('The transfer has been aborted and cannot be uploaded'); } $this->stopped = false; $eventData = $this->getEventData(); $this->dispatch(self::BEFORE_UPLOAD, $eventData); try { $this->transfer(); $this->dispatch(self::AFTER_UPLOAD, $eventData); if ($this->stopped) { return null; } else { $result = $this->complete(); $this->dispatch(self::AFTER_COMPLETE, $eventData); } } catch (\Exception $e) { throw new MultipartUploadException($this->state, $e); } return $result; } /** * Get an array used for event notifications * * @param OperationCommand $command Command to include in event data * * @return array */ protected function getEventData(OperationCommand $command = null) { $data = array( 'transfer' => $this, 'source' => $this->source, 'options' => $this->options, 'client' => $this->client, 'part_size' => $this->partSize, 'state' => $this->state ); if ($command) { $data['command'] = $command; } return $data; } /** * Hook to initialize the transfer */ protected function init() {} /** * Determine the upload part size based on the size of the source data and * taking into account the acceptable minimum and maximum part sizes. * * @return int The part size */ abstract protected function calculatePartSize(); /** * Complete the multipart upload * * @return Model Returns the result of the complete multipart upload command */ abstract protected function complete(); /** * Hook to implement in subclasses to perform the actual transfer */ abstract protected function transfer(); /** * Fetches the abort command fom the concrete implementation * * @return OperationCommand */ abstract protected function getAbortCommand(); } sdk-2.5.2/Aws/Common/Model/MultipartUpload/AbstractTransferState.php000064411532700161006750000000706512272324172022550 0ustar uploadId = $uploadId; } /** * {@inheritdoc} */ public function getUploadId() { return $this->uploadId; } /** * Get a data value from the transfer state's uploadId * * @param string $key Key to retrieve (e.g. Bucket, Key, UploadId, etc) * * @return string|null */ public function getFromId($key) { $params = $this->uploadId->toParams(); return isset($params[$key]) ? $params[$key] : null; } /** * {@inheritdoc} */ public function getPart($partNumber) { return isset($this->parts[$partNumber]) ? $this->parts[$partNumber] : null; } /** * {@inheritdoc} */ public function addPart(UploadPartInterface $part) { $partNumber = $part->getPartNumber(); $this->parts[$partNumber] = $part; return $this; } /** * {@inheritdoc} */ public function hasPart($partNumber) { return isset($this->parts[$partNumber]); } /** * {@inheritdoc} */ public function getPartNumbers() { return array_keys($this->parts); } /** * {@inheritdoc} */ public function setAborted($aborted) { $this->aborted = (bool) $aborted; return $this; } /** * {@inheritdoc} */ public function isAborted() { return $this->aborted; } /** * {@inheritdoc} */ public function count() { return count($this->parts); } /** * {@inheritdoc} */ public function getIterator() { return new \ArrayIterator($this->parts); } /** * {@inheritdoc} */ public function serialize() { return serialize(get_object_vars($this)); } /** * {@inheritdoc} */ public function unserialize($serialized) { $data = unserialize($serialized); foreach (get_object_vars($this) as $property => $oldValue) { if (array_key_exists($property, $data)) { $this->{$property} = $data[$property]; } else { throw new RuntimeException("The {$property} property could be restored during unserialization."); } } } } sdk-2.5.2/Aws/Common/Model/MultipartUpload/AbstractUploadBuilder.php000064411532700161006750000001031712272324172022510 0ustar client = $client; return $this; } /** * Set the state of the upload. This is useful for resuming from a previously started multipart upload. * You must use a local file stream as the data source if you wish to resume from a previous upload. * * @param TransferStateInterface|string $state Pass a TransferStateInterface object or the ID of the initiated * multipart upload. When an ID is passed, the builder will create a * state object using the data from a ListParts API response. * * @return self */ public function resumeFrom($state) { $this->state = $state; return $this; } /** * Set the data source of the transfer * * @param resource|string|EntityBody $source Source of the transfer. Pass a string to transfer from a file on disk. * You can also stream from a resource returned from fopen or a Guzzle * {@see EntityBody} object. * * @return self * @throws InvalidArgumentException when the source cannot be found or opened */ public function setSource($source) { // Use the contents of a file as the data source if (is_string($source)) { if (!file_exists($source)) { throw new InvalidArgumentException("File does not exist: {$source}"); } // Clear the cache so that we send accurate file sizes clearstatcache(true, $source); $source = fopen($source, 'r'); } $this->source = EntityBody::factory($source); if ($this->source->isSeekable() && $this->source->getSize() == 0) { throw new InvalidArgumentException('Empty body provided to upload builder'); } return $this; } /** * Specify the headers to set on the upload * * @param array $headers Headers to add to the uploaded object * * @return self */ public function setHeaders(array $headers) { $this->headers = $headers; return $this; } /** * Build the appropriate uploader based on the builder options * * @return TransferInterface */ abstract public function build(); /** * Initiate the multipart upload * * @return TransferStateInterface */ abstract protected function initiateMultipartUpload(); } sdk-2.5.2/Aws/Common/Model/MultipartUpload/AbstractUploadId.php000064411532700161006750000000435612272324172021464 0ustar loadData($data); return $uploadId; } /** * {@inheritdoc} */ public function toParams() { return $this->data; } /** * {@inheritdoc} */ public function serialize() { return serialize($this->data); } /** * {@inheritdoc} */ public function unserialize($serialized) { $this->loadData(unserialize($serialized)); } /** * Loads an array of data into the UploadId by extracting only the needed keys * * @param array $data Data to load * * @throws InvalidArgumentException if a required key is missing */ protected function loadData($data) { $data = array_replace(static::$expectedValues, array_intersect_key($data, static::$expectedValues)); foreach ($data as $key => $value) { if (isset($data[$key])) { $this->data[$key] = $data[$key]; } else { throw new InvalidArgumentException("A required key [$key] was missing from the UploadId."); } } } } sdk-2.5.2/Aws/Common/Model/MultipartUpload/AbstractUploadPart.php000064411532700161006750000000474112272324172022034 0ustar loadData($data); return $part; } /** * {@inheritdoc} */ public function getPartNumber() { return $this->partNumber; } /** * {@inheritdoc} */ public function toArray() { $array = array(); foreach (static::$keyMap as $key => $property) { $array[$key] = $this->{$property}; } return $array; } /** * {@inheritdoc} */ public function serialize() { return serialize($this->toArray()); } /** * {@inheritdoc} */ public function unserialize($serialized) { $this->loadData(unserialize($serialized)); } /** * Loads an array of data into the upload part by extracting only the needed keys * * @param array|\Traversable $data Data to load into the upload part value object * * @throws InvalidArgumentException if a required key is missing */ protected function loadData($data) { foreach (static::$keyMap as $key => $property) { if (isset($data[$key])) { $this->{$property} = $data[$key]; } else { throw new InvalidArgumentException("A required key [$key] was missing from the upload part."); } } } } sdk-2.5.2/Aws/Common/Model/MultipartUpload/TransferInterface.php000064411532700161006750000000351712272324172021702 0ustar 'Aws\Common\Aws', 'services' => array( 'default_settings' => array( 'params' => array() ), 'autoscaling' => array( 'alias' => 'AutoScaling', 'extends' => 'default_settings', 'class' => 'Aws\AutoScaling\AutoScalingClient' ), 'cloudformation' => array( 'alias' => 'CloudFormation', 'extends' => 'default_settings', 'class' => 'Aws\CloudFormation\CloudFormationClient' ), 'cloudfront' => array( 'alias' => 'CloudFront', 'extends' => 'default_settings', 'class' => 'Aws\CloudFront\CloudFrontClient' ), 'cloudfront_20120505' => array( 'extends' => 'cloudfront', 'params' => array( 'version' => '2012-05-05' ) ), 'cloudsearch' => array( 'alias' => 'CloudSearch', 'extends' => 'default_settings', 'class' => 'Aws\CloudSearch\CloudSearchClient' ), 'cloudtrail' => array( 'alias' => 'CloudTrail', 'extends' => 'default_settings', 'class' => 'Aws\CloudTrail\CloudTrailClient' ), 'cloudwatch' => array( 'alias' => 'CloudWatch', 'extends' => 'default_settings', 'class' => 'Aws\CloudWatch\CloudWatchClient' ), 'datapipeline' => array( 'alias' => 'DataPipeline', 'extends' => 'default_settings', 'class' => 'Aws\DataPipeline\DataPipelineClient' ), 'directconnect' => array( 'alias' => 'DirectConnect', 'extends' => 'default_settings', 'class' => 'Aws\DirectConnect\DirectConnectClient' ), 'dynamodb' => array( 'alias' => 'DynamoDb', 'extends' => 'default_settings', 'class' => 'Aws\DynamoDb\DynamoDbClient' ), 'dynamodb_20111205' => array( 'extends' => 'dynamodb', 'params' => array( 'version' => '2011-12-05' ) ), 'ec2' => array( 'alias' => 'Ec2', 'extends' => 'default_settings', 'class' => 'Aws\Ec2\Ec2Client' ), 'elasticache' => array( 'alias' => 'ElastiCache', 'extends' => 'default_settings', 'class' => 'Aws\ElastiCache\ElastiCacheClient' ), 'elasticbeanstalk' => array( 'alias' => 'ElasticBeanstalk', 'extends' => 'default_settings', 'class' => 'Aws\ElasticBeanstalk\ElasticBeanstalkClient' ), 'elasticloadbalancing' => array( 'alias' => 'ElasticLoadBalancing', 'extends' => 'default_settings', 'class' => 'Aws\ElasticLoadBalancing\ElasticLoadBalancingClient' ), 'elastictranscoder' => array( 'alias' => 'ElasticTranscoder', 'extends' => 'default_settings', 'class' => 'Aws\ElasticTranscoder\ElasticTranscoderClient' ), 'emr' => array( 'alias' => 'Emr', 'extends' => 'default_settings', 'class' => 'Aws\Emr\EmrClient' ), 'glacier' => array( 'alias' => 'Glacier', 'extends' => 'default_settings', 'class' => 'Aws\Glacier\GlacierClient' ), 'kinesis' => array( 'alias' => 'Kinesis', 'extends' => 'default_settings', 'class' => 'Aws\Kinesis\KinesisClient' ), 'iam' => array( 'alias' => 'Iam', 'extends' => 'default_settings', 'class' => 'Aws\Iam\IamClient' ), 'importexport' => array( 'alias' => 'ImportExport', 'extends' => 'default_settings', 'class' => 'Aws\ImportExport\ImportExportClient' ), 'opsworks' => array( 'alias' => 'OpsWorks', 'extends' => 'default_settings', 'class' => 'Aws\OpsWorks\OpsWorksClient' ), 'rds' => array( 'alias' => 'Rds', 'extends' => 'default_settings', 'class' => 'Aws\Rds\RdsClient' ), 'redshift' => array( 'alias' => 'Redshift', 'extends' => 'default_settings', 'class' => 'Aws\Redshift\RedshiftClient' ), 'route53' => array( 'alias' => 'Route53', 'extends' => 'default_settings', 'class' => 'Aws\Route53\Route53Client' ), 's3' => array( 'alias' => 'S3', 'extends' => 'default_settings', 'class' => 'Aws\S3\S3Client' ), 'sdb' => array( 'alias' => 'SimpleDb', 'extends' => 'default_settings', 'class' => 'Aws\SimpleDb\SimpleDbClient' ), 'ses' => array( 'alias' => 'Ses', 'extends' => 'default_settings', 'class' => 'Aws\Ses\SesClient' ), 'sns' => array( 'alias' => 'Sns', 'extends' => 'default_settings', 'class' => 'Aws\Sns\SnsClient' ), 'sqs' => array( 'alias' => 'Sqs', 'extends' => 'default_settings', 'class' => 'Aws\Sqs\SqsClient' ), 'storagegateway' => array( 'alias' => 'StorageGateway', 'extends' => 'default_settings', 'class' => 'Aws\StorageGateway\StorageGatewayClient' ), 'sts' => array( 'alias' => 'Sts', 'extends' => 'default_settings', 'class' => 'Aws\Sts\StsClient' ), 'support' => array( 'alias' => 'Support', 'extends' => 'default_settings', 'class' => 'Aws\Support\SupportClient' ), 'swf' => array( 'alias' => 'Swf', 'extends' => 'default_settings', 'class' => 'Aws\Swf\SwfClient' ), ) ); sdk-2.5.2/Aws/Common/Resources/sdk1-config.php000064411532700161006750000000705012272324172016162 0ustar array('_aws'), 'services' => array( 'sdk1_settings' => array( 'extends' => 'default_settings', 'params' => array( 'certificate_authority' => false ) ), 'v1.autoscaling' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonAS' ), 'v1.cloudformation' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonCloudFormation' ), 'v1.cloudfront' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonCloudFront' ), 'v1.cloudsearch' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonCloudSearch' ), 'v1.cloudwatch' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonCloudWatch' ), 'v1.dynamodb' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonDynamoDB' ), 'v1.ec2' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonEC2' ), 'v1.elasticache' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonElastiCache' ), 'v1.elasticbeanstalk' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonElasticBeanstalk' ), 'v1.elb' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonELB' ), 'v1.emr' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonEMR' ), 'v1.iam' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonIAM' ), 'v1.importexport' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonImportExport' ), 'v1.rds' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonRDS' ), 'v1.s3' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonS3' ), 'v1.sdb' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSDB' ), 'v1.ses' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSES' ), 'v1.sns' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSNS' ), 'v1.sqs' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSQS' ), 'v1.storagegateway' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonStorageGateway' ), 'v1.sts' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSTS' ), 'v1.swf' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSWF' ) ) ); sdk-2.5.2/Aws/Common/Signature/AbstractSignature.php000064411532700161006750000000160112272324172017465 0ustar credentials = $credentials; $this->signature = $signature; } /** * {@inheritdoc} */ public static function getSubscribedEvents() { return array( 'request.before_send' => array('onRequestBeforeSend', -255), 'client.credentials_changed' => array('onCredentialsChanged') ); } /** * Updates the listener with new credentials if the client is updated * * @param Event $event Event emitted */ public function onCredentialsChanged(Event $event) { $this->credentials = $event['credentials']; } /** * Signs requests before they are sent * * @param Event $event Event emitted */ public function onRequestBeforeSend(Event $event) { $this->signature->signRequest($event['request'], $this->credentials); } } sdk-2.5.2/Aws/Common/Signature/SignatureV2.php000064411532700161006750000000706512272324172016223 0ustar getTimestamp(true); // set values we need in CanonicalizedParameterString $this->addParameter($request, 'Timestamp', gmdate('c', $timestamp)); $this->addParameter($request, 'SignatureVersion', '2'); $this->addParameter($request, 'SignatureMethod', 'HmacSHA256'); $this->addParameter($request, 'AWSAccessKeyId', $credentials->getAccessKeyId()); if ($token = $credentials->getSecurityToken()) { $this->addParameter($request, 'SecurityToken', $token); } // Get the path and ensure it's absolute $path = '/' . ltrim($request->getUrl(true)->normalizePath()->getPath(), '/'); // build string to sign $sign = $request->getMethod() . "\n" . $request->getHost() . "\n" . $path . "\n" . $this->getCanonicalizedParameterString($request); // Add the string to sign to the request for debugging purposes $request->getParams()->set('aws.string_to_sign', $sign); $signature = base64_encode( hash_hmac( 'sha256', $sign, $credentials->getSecretKey(), true ) ); $this->addParameter($request, 'Signature', $signature); } /** * Add a parameter key and value to the request according to type * * @param RequestInterface $request The request * @param string $key The name of the parameter * @param string $value The value of the parameter */ public function addParameter(RequestInterface $request, $key, $value) { if ($request->getMethod() == 'POST') { $request->setPostField($key, $value); } else { $request->getQuery()->set($key, $value); } } /** * Get the canonicalized query/parameter string for a request * * @param RequestInterface $request Request used to build canonicalized string * * @return string */ private function getCanonicalizedParameterString(RequestInterface $request) { if ($request->getMethod() == 'POST') { $params = $request->getPostFields()->toArray(); } else { $params = $request->getQuery()->toArray(); } // Don't resign a previous signature value unset($params['Signature']); uksort($params, 'strcmp'); $str = ''; foreach ($params as $key => $val) { $str .= rawurlencode($key) . '=' . rawurlencode($val) . '&'; } return substr($str, 0, -1); } } sdk-2.5.2/Aws/Common/Signature/SignatureV3Https.php000064411532700161006750000000410112272324172017233 0ustar hasHeader('date') && !$request->hasHeader('x-amz-date')) { $request->setHeader('Date', gmdate(DateFormat::RFC1123, $this->getTimestamp())); } // Add the security token if one is present if ($credentials->getSecurityToken()) { $request->setHeader('x-amz-security-token', $credentials->getSecurityToken()); } // Determine the string to sign $stringToSign = (string) ($request->getHeader('Date') ?: $request->getHeader('x-amz-date')); $request->getParams()->set('aws.string_to_sign', $stringToSign); // Calculate the signature $signature = base64_encode(hash_hmac('sha256', $stringToSign, $credentials->getSecretKey(), true)); // Add the authorization header to the request $headerFormat = 'AWS3-HTTPS AWSAccessKeyId=%s,Algorithm=HmacSHA256,Signature=%s'; $request->setHeader('X-Amzn-Authorization', sprintf($headerFormat, $credentials->getAccessKeyId(), $signature)); } } sdk-2.5.2/Aws/Common/Signature/SignatureV4.php000064411532700161006750000002425012272324172016220 0ustar serviceName = $serviceName; $this->regionName = $regionName; } /** * Set the service name instead of inferring it from a request URL * * @param string $service Name of the service used when signing * * @return self */ public function setServiceName($service) { $this->serviceName = $service; return $this; } /** * Set the region name instead of inferring it from a request URL * * @param string $region Name of the region used when signing * * @return self */ public function setRegionName($region) { $this->regionName = $region; return $this; } /** * Set the maximum number of computed hashes to cache * * @param int $maxCacheSize Maximum number of hashes to cache * * @return self */ public function setMaxCacheSize($maxCacheSize) { $this->maxCacheSize = $maxCacheSize; return $this; } public function signRequest(RequestInterface $request, CredentialsInterface $credentials) { $timestamp = $this->getTimestamp(); $longDate = gmdate(DateFormat::ISO8601, $timestamp); $shortDate = substr($longDate, 0, 8); // Remove any previously set Authorization headers so that retries work $request->removeHeader('Authorization'); // Requires a x-amz-date header or Date if ($request->hasHeader('x-amz-date') || !$request->hasHeader('Date')) { $request->setHeader('x-amz-date', $longDate); } else { $request->setHeader('Date', gmdate(DateFormat::RFC1123, $timestamp)); } // Add the security token if one is present if ($credentials->getSecurityToken()) { $request->setHeader('x-amz-security-token', $credentials->getSecurityToken()); } // Parse the service and region or use one that is explicitly set $region = $this->regionName; $service = $this->serviceName; if (!$region || !$service) { $url = Url::factory($request->getUrl()); $region = $region ?: HostNameUtils::parseRegionName($url); $service = $service ?: HostNameUtils::parseServiceName($url); } $credentialScope = "{$shortDate}/{$region}/{$service}/aws4_request"; // Calculate the request signature payload if ($request->hasHeader('x-amz-content-sha256')) { // Handle streaming operations (e.g. Glacier.UploadArchive) $payload = $request->getHeader('x-amz-content-sha256'); } elseif ($request instanceof EntityEnclosingRequestInterface) { $payload = hash( 'sha256', $request->getMethod() == 'POST' && count($request->getPostFields()) ? (string) $request->getPostFields() : (string) $request->getBody() ); } else { // Use the default payload if there is no body $payload = self::DEFAULT_PAYLOAD; } $signingContext = $this->createSigningContext($request, $payload); $signingContext['string_to_sign'] = "AWS4-HMAC-SHA256\n{$longDate}\n{$credentialScope}\n" . hash('sha256', $signingContext['canonical_request']); // Calculate the signing key using a series of derived keys $signingKey = $this->getSigningKey($shortDate, $region, $service, $credentials->getSecretKey()); $signature = hash_hmac('sha256', $signingContext['string_to_sign'], $signingKey); $request->setHeader('Authorization', "AWS4-HMAC-SHA256 " . "Credential={$credentials->getAccessKeyId()}/{$credentialScope}, " . "SignedHeaders={$signingContext['signed_headers']}, Signature={$signature}"); // Add debug information to the request $request->getParams()->set('aws.signature', $signingContext); } /** * Create the canonical representation of a request * * @param RequestInterface $request Request to canonicalize * @param string $payload Request payload (typically the value * of the x-amz-content-sha256 header. * * @return array Returns an array of context information including: * - canonical_request * - signed_headers */ protected function createSigningContext(RequestInterface $request, $payload) { // Normalize the path as required by SigV4 and ensure it's absolute $canon = $request->getMethod() . "\n" . $this->normalizePath($request) . "\n" . $this->getCanonicalizedQueryString($request) . "\n"; // Create the canonical headers $headers = array(); foreach ($request->getHeaders()->getAll() as $key => $values) { $key = strtolower($key); if ($key != 'user-agent') { $headers[$key] = array(); foreach ($values as $value) { $headers[$key][] = preg_replace('/\s+/', ' ', trim($value)); } // Sort the value if there is more than one if (count($values) > 1) { sort($headers[$key]); } } } // The headers must be sorted ksort($headers); // Continue to build the canonical request by adding headers foreach ($headers as $key => $values) { // Combine multi-value headers into a comma separated list $canon .= $key . ':' . implode(',', $values) . "\n"; } // Create the signed headers $signedHeaders = implode(';', array_keys($headers)); $canon .= "\n{$signedHeaders}\n{$payload}"; return array( 'canonical_request' => $canon, 'signed_headers' => $signedHeaders ); } /** * Get the normalized path of a request * * @param RequestInterface $request Request to normalize * * @return string Returns the normalized path */ protected function normalizePath(RequestInterface $request) { return '/' . ltrim($request->getUrl(true)->normalizePath()->getPath(), '/'); } /** * Get a hash for a specific key and value. If the hash was previously * cached, return it * * @param string $shortDate Short date * @param string $region Region name * @param string $service Service name * @param string $secretKey Secret Access Key * * @return string */ protected function getSigningKey($shortDate, $region, $service, $secretKey) { $cacheKey = $shortDate . '_' . $region . '_' . $service . '_' . $secretKey; // Retrieve the hash form the cache or create it and add it to the cache if (!isset($this->hashCache[$cacheKey])) { // When the cache size reaches the max, then just clear the cache if (++$this->cacheSize > $this->maxCacheSize) { $this->hashCache = array(); $this->cacheSize = 0; } $dateKey = hash_hmac('sha256', $shortDate, 'AWS4' . $secretKey, true); $regionKey = hash_hmac('sha256', $region, $dateKey, true); $serviceKey = hash_hmac('sha256', $service, $regionKey, true); $this->hashCache[$cacheKey] = hash_hmac('sha256', 'aws4_request', $serviceKey, true); } return $this->hashCache[$cacheKey]; } /** * Get the canonicalized query string for a request * * @param RequestInterface $request * @return string */ private function getCanonicalizedQueryString(RequestInterface $request) { $queryParams = $request->getQuery()->getAll(); unset($queryParams['X-Amz-Signature']); if (empty($queryParams)) { return ''; } $qs = ''; ksort($queryParams); foreach ($queryParams as $key => $values) { if (is_array($values)) { sort($values); } elseif (!$values) { $values = array(''); } foreach ((array) $values as $value) { if ($value === QueryString::BLANK) { $value = ''; } $qs .= rawurlencode($key) . '=' . rawurlencode($value) . '&'; } } return substr($qs, 0, -1); } } sdk-2.5.2/Aws/Common/Waiter/AbstractResourceWaiter.php000064411532700161006750000000247212272324172017770 0ustar client = $client; return $this; } /** * {@inheritdoc} */ public function wait() { if (!$this->client) { throw new RuntimeException('No client has been specified on the waiter'); } parent::wait(); } } sdk-2.5.2/Aws/Common/Waiter/AbstractWaiter.php000064411532700161006750000000722112272324172016255 0ustar config[self::MAX_ATTEMPTS]) ? $this->config[self::MAX_ATTEMPTS] : 10; } /** * Get the amount of time in seconds to delay between attempts * * @return int */ public function getInterval() { return isset($this->config[self::INTERVAL]) ? $this->config[self::INTERVAL] : 0; } /** * {@inheritdoc} */ public function setMaxAttempts($maxAttempts) { $this->config[self::MAX_ATTEMPTS] = $maxAttempts; return $this; } /** * {@inheritdoc} */ public function setInterval($interval) { $this->config[self::INTERVAL] = $interval; return $this; } /** * Set config options associated with the waiter * * @param array $config Options to set * * @return self */ public function setConfig(array $config) { if (isset($config['waiter.before_attempt'])) { $this->getEventDispatcher()->addListener('waiter.before_attempt', $config['waiter.before_attempt']); unset($config['waiter.before_attempt']); } if (isset($config['waiter.before_wait'])) { $this->getEventDispatcher()->addListener('waiter.before_wait', $config['waiter.before_wait']); unset($config['waiter.before_wait']); } $this->config = $config; return $this; } /** * {@inheritdoc} */ public function wait() { $this->attempts = 0; do { $this->dispatch('waiter.before_attempt', array( 'waiter' => $this, 'config' => $this->config, )); if ($this->doWait()) { break; } if (++$this->attempts >= $this->getMaxAttempts()) { throw new RuntimeException('Wait method never resolved to true after ' . $this->attempts . ' attempts'); } $this->dispatch('waiter.before_wait', array( 'waiter' => $this, 'config' => $this->config, )); if ($this->getInterval()) { usleep($this->getInterval() * 1000000); } } while (1); } /** * Method to implement in subclasses * * @return bool Return true when successful, false on failure */ abstract protected function doWait(); } sdk-2.5.2/Aws/Common/Waiter/CallableWaiter.php000064411532700161006750000000411012272324172016203 0ustar callable = $callable; return $this; } /** * Set additional context for the callable function. This data will be passed into the callable function as the * second argument * * @param array $context Additional context * * @return self */ public function setContext(array $context) { $this->context = $context; return $this; } /** * {@inheritdoc} */ public function doWait() { if (!$this->callable) { throw new RuntimeException('No callable was specified for the wait method'); } return call_user_func($this->callable, $this->attempts, $this->context); } } sdk-2.5.2/Aws/Common/Waiter/CompositeWaiterFactory.php000064411532700161006750000000424512272324172020007 0ustar factories = $factories; } /** * {@inheritdoc} */ public function build($waiter) { if (!($factory = $this->getFactory($waiter))) { throw new InvalidArgumentException("Waiter was not found matching {$waiter}."); } return $factory->build($waiter); } /** * {@inheritdoc} */ public function canBuild($waiter) { return (bool) $this->getFactory($waiter); } /** * Add a factory to the composite factory * * @param WaiterFactoryInterface $factory Factory to add * * @return self */ public function addFactory(WaiterFactoryInterface $factory) { $this->factories[] = $factory; return $this; } /** * Get the factory that matches the waiter name * * @param string $waiter Name of the waiter * * @return WaiterFactoryInterface|bool */ protected function getFactory($waiter) { foreach ($this->factories as $factory) { if ($factory->canBuild($waiter)) { return $factory; } } return false; } } sdk-2.5.2/Aws/Common/Waiter/ConfigResourceWaiter.php000064411532700161006750000001656412272324172017441 0ustar waiterConfig = $waiterConfig; $this->setInterval($waiterConfig->get(WaiterConfig::INTERVAL)); $this->setMaxAttempts($waiterConfig->get(WaiterConfig::MAX_ATTEMPTS)); } /** * {@inheritdoc} */ public function setConfig(array $config) { foreach ($config as $key => $value) { if (substr($key, 0, 7) == 'waiter.') { $this->waiterConfig->set(substr($key, 7), $value); } } if (!isset($config[self::INTERVAL])) { $config[self::INTERVAL] = $this->waiterConfig->get(WaiterConfig::INTERVAL); } if (!isset($config[self::MAX_ATTEMPTS])) { $config[self::MAX_ATTEMPTS] = $this->waiterConfig->get(WaiterConfig::MAX_ATTEMPTS); } return parent::setConfig($config); } /** * Get the waiter's configuration data * * @return WaiterConfig */ public function getWaiterConfig() { return $this->waiterConfig; } /** * {@inheritdoc} */ protected function doWait() { $params = $this->config; // remove waiter settings from the operation's input foreach (array_keys($params) as $key) { if (substr($key, 0, 7) == 'waiter.') { unset($params[$key]); } } $operation = $this->client->getCommand($this->waiterConfig->get(WaiterConfig::OPERATION), $params); try { return $this->checkResult($this->client->execute($operation)); } catch (ValidationException $e) { throw new InvalidArgumentException( $this->waiterConfig->get(WaiterConfig::WAITER_NAME) . ' waiter validation failed: ' . $e->getMessage(), $e->getCode(), $e ); } catch (ServiceResponseException $e) { // Check if this exception satisfies a success or failure acceptor $transition = $this->checkErrorAcceptor($e); if (null !== $transition) { return $transition; } // Check if this exception should be ignored foreach ((array) $this->waiterConfig->get(WaiterConfig::IGNORE_ERRORS) as $ignore) { if ($e->getExceptionCode() == $ignore) { // This exception is ignored, so it counts as a failed attempt rather than a fast-fail return false; } } // Allow non-ignore exceptions to bubble through throw $e; } } /** * Check if an exception satisfies a success or failure acceptor * * @param ServiceResponseException $e * * @return bool|null Returns true for success, false for failure, and null for no transition */ protected function checkErrorAcceptor(ServiceResponseException $e) { if ($this->waiterConfig->get(WaiterConfig::SUCCESS_TYPE) == 'error') { if ($e->getExceptionCode() == $this->waiterConfig->get(WaiterConfig::SUCCESS_VALUE)) { // Mark as a success return true; } } // Mark as an attempt return null; } /** * Check to see if the response model satisfies a success or failure state * * @param Model $result Result model * * @return bool * @throws RuntimeException */ protected function checkResult(Model $result) { // Check if the result evaluates to true based on the path and output model if ($this->waiterConfig->get(WaiterConfig::SUCCESS_TYPE) == 'output' && $this->checkPath( $result, $this->waiterConfig->get(WaiterConfig::SUCCESS_PATH), $this->waiterConfig->get(WaiterConfig::SUCCESS_VALUE) ) ) { return true; } // It did not finish waiting yet. Determine if we need to fail-fast based on the failure acceptor. if ($this->waiterConfig->get(WaiterConfig::FAILURE_TYPE) == 'output') { $failureValue = $this->waiterConfig->get(WaiterConfig::FAILURE_VALUE); if ($failureValue) { $key = $this->waiterConfig->get(WaiterConfig::FAILURE_PATH); if ($this->checkPath($result, $key, $failureValue, false)) { // Determine which of the results triggered the failure $triggered = array_intersect( (array) $this->waiterConfig->get(WaiterConfig::FAILURE_VALUE), array_unique((array) $result->getPath($key)) ); // fast fail because the failure case was satisfied throw new RuntimeException( 'A resource entered into an invalid state of "' . implode(', ', $triggered) . '" while waiting with the "' . $this->waiterConfig->get(WaiterConfig::WAITER_NAME) . '" waiter.' ); } } } return false; } /** * Check to see if the path of the output key is satisfied by the value * * @param Model $model Result model * @param string $key Key to check * @param string $checkValue Compare the key to the value * @param bool $all Set to true to ensure all value match or false to only match one * * @return bool */ protected function checkPath(Model $model, $key = null, $checkValue = array(), $all = true) { // If no key is set, then just assume true because the request succeeded if (!$key) { return true; } if (!($result = $model->getPath($key))) { return false; } $total = $matches = 0; foreach ((array) $result as $value) { $total++; foreach ((array) $checkValue as $check) { if ($value == $check) { $matches++; break; } } } // When matching all values, ensure that the match count matches the total count if ($all && $total != $matches) { return false; } return $matches > 0; } } sdk-2.5.2/Aws/Common/Waiter/ResourceWaiterInterface.php000064411532700161006750000000201012272324172020111 0ustar CamelCase). */ class WaiterClassFactory implements WaiterFactoryInterface { /** * @var array List of namespaces used to look for classes */ protected $namespaces; /** * @var InflectorInterface Inflector used to inflect class names */ protected $inflector; /** * @param array|string $namespaces Namespaces of waiter objects * @param InflectorInterface $inflector Inflector used to resolve class names */ public function __construct($namespaces = array(), InflectorInterface $inflector = null) { $this->namespaces = (array) $namespaces; $this->inflector = $inflector ?: Inflector::getDefault(); } /** * Registers a namespace to check for Waiters * * @param string $namespace Namespace which contains Waiter classes * * @return self */ public function registerNamespace($namespace) { array_unshift($this->namespaces, $namespace); return $this; } /** * {@inheritdoc} */ public function build($waiter) { if (!($className = $this->getClassName($waiter))) { throw new InvalidArgumentException("Waiter was not found matching {$waiter}."); } return new $className(); } /** * {@inheritdoc} */ public function canBuild($waiter) { return $this->getClassName($waiter) !== null; } /** * Get the name of a waiter class * * @param string $waiter Waiter name * * @return string|null */ protected function getClassName($waiter) { $waiterName = $this->inflector->camel($waiter); // Determine the name of the class to load $className = null; foreach ($this->namespaces as $namespace) { $potentialClassName = $namespace . '\\' . $waiterName; if (class_exists($potentialClassName)) { return $potentialClassName; } } return null; } } sdk-2.5.2/Aws/Common/Waiter/WaiterConfig.php000064411532700161006750000000406712272324172015724 0ustar data = $data; $this->extractConfig(); } /** * Create the command configuration variables */ protected function extractConfig() { // Populate success.* and failure.* if specified in acceptor.* foreach ($this->data as $key => $value) { if (substr($key, 0, 9) == 'acceptor.') { $name = substr($key, 9); if (!isset($this->data["success.{$name}"])) { $this->data["success.{$name}"] = $value; } if (!isset($this->data["failure.{$name}"])) { $this->data["failure.{$name}"] = $value; } unset($this->data[$key]); } } } } sdk-2.5.2/Aws/Common/Waiter/WaiterConfigFactory.php000064411532700161006750000000563612272324172017257 0ustar config = $config; $this->inflector = $inflector ?: Inflector::getDefault(); } /** * {@inheritdoc} */ public function build($waiter) { return new ConfigResourceWaiter($this->getWaiterConfig($waiter)); } /** * {@inheritdoc} */ public function canBuild($waiter) { return isset($this->config[$waiter]) || isset($this->config[$this->inflector->camel($waiter)]); } /** * Get waiter configuration data, taking __default__ and extensions into account * * @param string $name Waiter name * * @return WaiterConfig * @throws InvalidArgumentException */ protected function getWaiterConfig($name) { if (!$this->canBuild($name)) { throw new InvalidArgumentException('No waiter found matching "' . $name . '"'); } // inflect the name if needed $name = isset($this->config[$name]) ? $name : $this->inflector->camel($name); $waiter = new WaiterConfig($this->config[$name]); $waiter['name'] = $name; // Always use __default__ as the basis if it's set if (isset($this->config['__default__'])) { $parentWaiter = new WaiterConfig($this->config['__default__']); $waiter = $parentWaiter->overwriteWith($waiter); } // Allow for configuration extensions if (isset($this->config[$name]['extends'])) { $waiter = $this->getWaiterConfig($this->config[$name]['extends'])->overwriteWith($waiter); } return $waiter; } } sdk-2.5.2/Aws/Common/Waiter/WaiterFactoryInterface.php000064411532700161006750000000215212272324172017740 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/datapipeline-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->setIteratorsConfig(array( 'limit_key' => 'limit', 'more_key' => 'hasMoreResults', 'token_param' => 'marker', 'token_key' => 'marker', 'operations' => array( 'ListPipelines' => array( 'result_key' => 'pipelineIdList', ), 'DescribeObjects' => array( 'result_key' => 'pipelineObjects', ), 'QueryObjects' => array( 'result_key' => 'ids', ), ) )) ->build(); return $client; } } sdk-2.5.2/Aws/DataPipeline/Enum/WorkStatus.php000064411532700161006750000000146412272324172016247 0ustar '2012-10-29', 'endpointPrefix' => 'datapipeline', 'serviceFullName' => 'AWS Data Pipeline', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'DataPipeline.', 'signatureVersion' => 'v4', 'namespace' => 'DataPipeline', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'datapipeline.us-east-1.amazonaws.com', ), ), 'operations' => array( 'ActivatePipeline' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ActivatePipeline', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'CreatePipeline' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreatePipelineOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.CreatePipeline', ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'uniqueId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'DeletePipeline' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.DeletePipeline', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'DescribeObjects' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeObjectsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.DescribeObjects', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'objectIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'id', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'evaluateExpressions' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'marker' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'DescribePipelines' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribePipelinesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.DescribePipelines', ), 'pipelineIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'id', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'EvaluateExpression' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EvaluateExpressionOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.EvaluateExpression', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'objectId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'expression' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 20971520, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The specified task was not found.', 'class' => 'TaskNotFoundException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'GetPipelineDefinition' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetPipelineDefinitionOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.GetPipelineDefinition', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'version' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'ListPipelines' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListPipelinesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ListPipelines', ), 'marker' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'PollForTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PollForTaskOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.PollForTask', ), 'workerGroup' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'hostname' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'instanceIdentity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'document' => array( 'type' => 'string', 'maxLength' => 1024, ), 'signature' => array( 'type' => 'string', 'maxLength' => 1024, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified task was not found.', 'class' => 'TaskNotFoundException', ), ), ), 'PutPipelineDefinition' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PutPipelineDefinitionOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.PutPipelineDefinition', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'pipelineObjects' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineObject', 'type' => 'object', 'properties' => array( 'id' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), 'fields' => array( 'required' => true, 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'stringValue' => array( 'type' => 'string', 'maxLength' => 10240, ), 'refValue' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'QueryObjects' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'QueryObjectsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.QueryObjects', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'query' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'selectors' => array( 'type' => 'array', 'items' => array( 'name' => 'Selector', 'type' => 'object', 'properties' => array( 'fieldName' => array( 'type' => 'string', 'maxLength' => 1024, ), 'operator' => array( 'type' => 'object', 'properties' => array( '' => array( ), ), ), ), ), ), ), ), 'sphere' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'marker' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'limit' => array( 'type' => 'numeric', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'ReportTaskProgress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ReportTaskProgressOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ReportTaskProgress', ), 'taskId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified task was not found.', 'class' => 'TaskNotFoundException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'ReportTaskRunnerHeartbeat' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ReportTaskRunnerHeartbeatOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ReportTaskRunnerHeartbeat', ), 'taskrunnerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'workerGroup' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'hostname' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'SetStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.SetStatus', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'objectIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'id', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'status' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'SetTaskStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.SetTaskStatus', ), 'taskId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 2048, ), 'taskStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'errorId' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'errorMessage' => array( 'type' => 'string', 'location' => 'json', ), 'errorStackTrace' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The specified task was not found.', 'class' => 'TaskNotFoundException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'ValidatePipelineDefinition' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ValidatePipelineDefinitionOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ValidatePipelineDefinition', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'pipelineObjects' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineObject', 'type' => 'object', 'properties' => array( 'id' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), 'fields' => array( 'required' => true, 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'stringValue' => array( 'type' => 'string', 'maxLength' => 10240, ), 'refValue' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreatePipelineOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeObjectsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineObjects' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineObject', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'fields' => array( 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'type' => 'string', ), 'stringValue' => array( 'type' => 'string', ), 'refValue' => array( 'type' => 'string', ), ), ), ), ), ), ), 'marker' => array( 'type' => 'string', 'location' => 'json', ), 'hasMoreResults' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'DescribePipelinesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineDescriptionList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineDescription', 'type' => 'object', 'properties' => array( 'pipelineId' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'fields' => array( 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'type' => 'string', ), 'stringValue' => array( 'type' => 'string', ), 'refValue' => array( 'type' => 'string', ), ), ), ), 'description' => array( 'type' => 'string', ), ), ), ), ), ), 'EvaluateExpressionOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'evaluatedExpression' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'GetPipelineDefinitionOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineObjects' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineObject', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'fields' => array( 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'type' => 'string', ), 'stringValue' => array( 'type' => 'string', ), 'refValue' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ListPipelinesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineIdList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineIdName', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), ), ), ), 'marker' => array( 'type' => 'string', 'location' => 'json', ), 'hasMoreResults' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'PollForTaskOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'taskObject' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'taskId' => array( 'type' => 'string', ), 'pipelineId' => array( 'type' => 'string', ), 'attemptId' => array( 'type' => 'string', ), 'objects' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'fields' => array( 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'type' => 'string', ), 'stringValue' => array( 'type' => 'string', ), 'refValue' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'PutPipelineDefinitionOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'validationErrors' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ValidationError', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'errors' => array( 'type' => 'array', 'items' => array( 'name' => 'validationMessage', 'type' => 'string', ), ), ), ), ), 'validationWarnings' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ValidationWarning', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'warnings' => array( 'type' => 'array', 'items' => array( 'name' => 'validationMessage', 'type' => 'string', ), ), ), ), ), 'errored' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'QueryObjectsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ids' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'id', 'type' => 'string', ), ), 'marker' => array( 'type' => 'string', 'location' => 'json', ), 'hasMoreResults' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'ReportTaskProgressOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'canceled' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'ReportTaskRunnerHeartbeatOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'terminate' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'ValidatePipelineDefinitionOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'validationErrors' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ValidationError', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'errors' => array( 'type' => 'array', 'items' => array( 'name' => 'validationMessage', 'type' => 'string', ), ), ), ), ), 'validationWarnings' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ValidationWarning', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'warnings' => array( 'type' => 'array', 'items' => array( 'name' => 'validationMessage', 'type' => 'string', ), ), ), ), ), 'errored' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), ), ); sdk-2.5.2/Aws/DirectConnect/DirectConnectClient.php000064411532700161006750000001267612272324172017274 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/directconnect-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->setIteratorsConfig(array( 'operations' => array( 'DescribeConnections' => array( 'result_key' => 'connections', ), 'DescribeOfferings' => array( 'result_key' => 'offerings', ), 'DescribeVirtualGateways' => array( 'result_key' => 'virtualGateways', ), 'DescribeVirtualInterfaces' => array( 'result_key' => 'virtualInterfaces', ), ) )) ->build(); } } sdk-2.5.2/Aws/DirectConnect/Enum/ConnectionState.php000064411532700161006750000000174612272324172017411 0ustar '2012-10-25', 'endpointPrefix' => 'directconnect', 'serviceFullName' => 'AWS Direct Connect', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'OvertureService.', 'signatureVersion' => 'v4', 'namespace' => 'DirectConnect', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'AllocateConnectionOnInterconnect' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connection', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.AllocateConnectionOnInterconnect', ), 'bandwidth' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'connectionName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'ownerAccount' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'interconnectId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'AllocatePrivateVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterface', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.AllocatePrivateVirtualInterface', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'ownerAccount' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'newPrivateVirtualInterfaceAllocation' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'virtualInterfaceName' => array( 'required' => true, 'type' => 'string', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', ), 'asn' => array( 'required' => true, 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'type' => 'string', ), 'customerAddress' => array( 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'AllocatePublicVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterface', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.AllocatePublicVirtualInterface', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'ownerAccount' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'newPublicVirtualInterfaceAllocation' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'virtualInterfaceName' => array( 'required' => true, 'type' => 'string', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', ), 'asn' => array( 'required' => true, 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'required' => true, 'type' => 'string', ), 'customerAddress' => array( 'required' => true, 'type' => 'string', ), 'routeFilterPrefixes' => array( 'required' => true, 'type' => 'array', 'items' => array( 'name' => 'RouteFilterPrefix', 'type' => 'object', 'properties' => array( 'cidr' => array( 'type' => 'string', ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'ConfirmConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ConfirmConnectionResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.ConfirmConnection', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'ConfirmPrivateVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ConfirmPrivateVirtualInterfaceResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.ConfirmPrivateVirtualInterface', ), 'virtualInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'virtualGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'ConfirmPublicVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ConfirmPublicVirtualInterfaceResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.ConfirmPublicVirtualInterface', ), 'virtualInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'CreateConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connection', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.CreateConnection', ), 'location' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'bandwidth' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'connectionName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'CreateInterconnect' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Interconnect', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.CreateInterconnect', ), 'interconnectName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'bandwidth' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'location' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'CreatePrivateVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterface', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.CreatePrivateVirtualInterface', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'newPrivateVirtualInterface' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'virtualInterfaceName' => array( 'required' => true, 'type' => 'string', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', ), 'asn' => array( 'required' => true, 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'type' => 'string', ), 'customerAddress' => array( 'type' => 'string', ), 'virtualGatewayId' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'CreatePublicVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterface', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.CreatePublicVirtualInterface', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'newPublicVirtualInterface' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'virtualInterfaceName' => array( 'required' => true, 'type' => 'string', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', ), 'asn' => array( 'required' => true, 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'required' => true, 'type' => 'string', ), 'customerAddress' => array( 'required' => true, 'type' => 'string', ), 'routeFilterPrefixes' => array( 'required' => true, 'type' => 'array', 'items' => array( 'name' => 'RouteFilterPrefix', 'type' => 'object', 'properties' => array( 'cidr' => array( 'type' => 'string', ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DeleteConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connection', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DeleteConnection', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DeleteInterconnect' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteInterconnectResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DeleteInterconnect', ), 'interconnectId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DeleteVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteVirtualInterfaceResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DeleteVirtualInterface', ), 'virtualInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeConnections' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connections', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeConnections', ), 'connectionId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeConnectionsOnInterconnect' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connections', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeConnectionsOnInterconnect', ), 'interconnectId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeInterconnects' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Interconnects', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeInterconnects', ), 'interconnectId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeLocations' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Locations', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeLocations', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeVirtualGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualGateways', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeVirtualGateways', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeVirtualInterfaces' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterfaces', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeVirtualInterfaces', ), 'connectionId' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), ), 'models' => array( 'Connection' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ownerAccount' => array( 'type' => 'string', 'location' => 'json', ), 'connectionId' => array( 'type' => 'string', 'location' => 'json', ), 'connectionName' => array( 'type' => 'string', 'location' => 'json', ), 'connectionState' => array( 'type' => 'string', 'location' => 'json', ), 'region' => array( 'type' => 'string', 'location' => 'json', ), 'location' => array( 'type' => 'string', 'location' => 'json', ), 'bandwidth' => array( 'type' => 'string', 'location' => 'json', ), 'vlan' => array( 'type' => 'numeric', 'location' => 'json', ), 'partnerName' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'VirtualInterface' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ownerAccount' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceId' => array( 'type' => 'string', 'location' => 'json', ), 'location' => array( 'type' => 'string', 'location' => 'json', ), 'connectionId' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceType' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceName' => array( 'type' => 'string', 'location' => 'json', ), 'vlan' => array( 'type' => 'numeric', 'location' => 'json', ), 'asn' => array( 'type' => 'numeric', 'location' => 'json', ), 'authKey' => array( 'type' => 'string', 'location' => 'json', ), 'amazonAddress' => array( 'type' => 'string', 'location' => 'json', ), 'customerAddress' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceState' => array( 'type' => 'string', 'location' => 'json', ), 'customerRouterConfig' => array( 'type' => 'string', 'location' => 'json', ), 'virtualGatewayId' => array( 'type' => 'string', 'location' => 'json', ), 'routeFilterPrefixes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'RouteFilterPrefix', 'type' => 'object', 'properties' => array( 'cidr' => array( 'type' => 'string', ), ), ), ), ), ), 'ConfirmConnectionResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'connectionState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ConfirmPrivateVirtualInterfaceResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualInterfaceState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ConfirmPublicVirtualInterfaceResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualInterfaceState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'Interconnect' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'interconnectId' => array( 'type' => 'string', 'location' => 'json', ), 'interconnectName' => array( 'type' => 'string', 'location' => 'json', ), 'interconnectState' => array( 'type' => 'string', 'location' => 'json', ), 'region' => array( 'type' => 'string', 'location' => 'json', ), 'location' => array( 'type' => 'string', 'location' => 'json', ), 'bandwidth' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteInterconnectResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'interconnectState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteVirtualInterfaceResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualInterfaceState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'Connections' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'connections' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Connection', 'type' => 'object', 'properties' => array( 'ownerAccount' => array( 'type' => 'string', ), 'connectionId' => array( 'type' => 'string', ), 'connectionName' => array( 'type' => 'string', ), 'connectionState' => array( 'type' => 'string', ), 'region' => array( 'type' => 'string', ), 'location' => array( 'type' => 'string', ), 'bandwidth' => array( 'type' => 'string', ), 'vlan' => array( 'type' => 'numeric', ), 'partnerName' => array( 'type' => 'string', ), ), ), ), ), ), 'Interconnects' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'interconnects' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Interconnect', 'type' => 'object', 'properties' => array( 'interconnectId' => array( 'type' => 'string', ), 'interconnectName' => array( 'type' => 'string', ), 'interconnectState' => array( 'type' => 'string', ), 'region' => array( 'type' => 'string', ), 'location' => array( 'type' => 'string', ), 'bandwidth' => array( 'type' => 'string', ), ), ), ), ), ), 'Locations' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'locations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Location', 'type' => 'object', 'properties' => array( 'locationCode' => array( 'type' => 'string', ), 'locationName' => array( 'type' => 'string', ), ), ), ), ), ), 'VirtualGateways' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualGateways' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VirtualGateway', 'type' => 'object', 'properties' => array( 'virtualGatewayId' => array( 'type' => 'string', ), 'virtualGatewayState' => array( 'type' => 'string', ), ), ), ), ), ), 'VirtualInterfaces' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualInterfaces' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VirtualInterface', 'type' => 'object', 'properties' => array( 'ownerAccount' => array( 'type' => 'string', ), 'virtualInterfaceId' => array( 'type' => 'string', ), 'location' => array( 'type' => 'string', ), 'connectionId' => array( 'type' => 'string', ), 'virtualInterfaceType' => array( 'type' => 'string', ), 'virtualInterfaceName' => array( 'type' => 'string', ), 'vlan' => array( 'type' => 'numeric', ), 'asn' => array( 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'type' => 'string', ), 'customerAddress' => array( 'type' => 'string', ), 'virtualInterfaceState' => array( 'type' => 'string', ), 'customerRouterConfig' => array( 'type' => 'string', ), 'virtualGatewayId' => array( 'type' => 'string', ), 'routeFilterPrefixes' => array( 'type' => 'array', 'items' => array( 'name' => 'RouteFilterPrefix', 'type' => 'object', 'properties' => array( 'cidr' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ); sdk-2.5.2/Aws/DynamoDb/Crc32ErrorChecker.php000064411532700161006750000000360112272324172015521 0ustar setNext($next); } } /** * {@inheridoc} */ public function makesDecision() { return true; } /** * {@inheritdoc} */ protected function getDelay( $retries, RequestInterface $request, Response $response = null, HttpException $e = null ) { if ($response) { // Validate the checksum against our computed checksum if ($checksum = (string) $response->getHeader('x-amz-crc32')) { // Retry the request if the checksums don't match, otherwise, return null return $checksum != hexdec(Stream::getHash($response->getBody(), 'crc32b')) ? true : null; } } } } sdk-2.5.2/Aws/DynamoDb/DynamoDbClient.php000064411532700161006750000002150012272324172015200 0ustar setConfig($config) ->setConfigDefaults(array( // DynamoDB does not use redirects self::DISABLE_REDIRECTS => true, Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/dynamodb-%s.php', // DynamoDB does not require response processing other than turning JSON into an array self::COMMAND_PARAMS => array(Cmd::RESPONSE_PROCESSING => Cmd::TYPE_NO_TRANSLATION) )) ->setExceptionParser($exceptionParser) ->setIteratorsConfig(array( 'result_key' => 'Items', 'token_param' => 'ExclusiveStartKey', 'token_key' => 'LastEvaluatedKey', 'operations' => array( 'BatchGetItem' => array( 'token_param' => 'RequestItems', 'token_key' => 'UnprocessedKeys', 'result_key' => 'Responses/*', ), 'ListTables' => array( 'result_key' => 'TableNames', 'token_param' => 'ExclusiveStartTableName', 'token_key' => 'LastEvaluatedTableName', ), 'Query', 'Scan', ) )) ->build(); } /** * Formats a value as a DynamoDB attribute. * * @param mixed $value The value to format for DynamoDB. * @param string $format The type of format (e.g. put, update). * * @return array The formatted value. */ public function formatValue($value, $format = Attribute::FORMAT_PUT) { return Attribute::factory($value)->getFormatted($format); } /** * Formats an array of values as DynamoDB attributes. * * @param array $values The values to format for DynamoDB. * @param string $format The type of format (e.g. put, update). * * @return array The formatted values. */ public function formatAttributes(array $values, $format = Attribute::FORMAT_PUT) { $formatted = array(); foreach ($values as $key => $value) { $formatted[$key] = $this->formatValue($value, $format); } return $formatted; } /** * Calculate the amount of time needed for an exponential backoff to wait * before retrying a request * * @param int $retries Number of retries * * @return float Returns the amount of time to wait in seconds */ public static function calculateRetryDelay($retries) { return $retries == 0 ? 0 : (50 * (int) pow(2, $retries - 1)) / 1000; } /** * Convenience method for instantiating and registering the DynamoDB * Session handler with this DynamoDB client object. * * @param array $config Array of options for the session handler factory * * @return SessionHandler */ public function registerSessionHandler(array $config = array()) { $config = array_replace(array('dynamodb_client' => $this), $config); $handler = SessionHandler::factory($config); $handler->register(); return $handler; } } sdk-2.5.2/Aws/DynamoDb/Enum/AttributeAction.php000064411532700161006750000000145412272324172016357 0ustar addItem($unprocessedItem); } } /** * Adds an unprocessed write request to the collection * * @param WriteRequestInterface $unprocessedItem * * @return UnprocessedWriteRequestsException */ public function addItem(WriteRequestInterface $unprocessedItem) { $this->items[] = $unprocessedItem; return $this; } /** * Get the total number of request exceptions * * @return int */ public function count() { return count($this->items); } /** * Allows array-like iteration over the request exceptions * * @return \ArrayIterator */ public function getIterator() { return new \ArrayIterator($this->items); } } sdk-2.5.2/Aws/DynamoDb/Exception/UnrecognizedClientException.php000064411532700161006750000000133312272324172021756 0ustar get('Items'))) { if ($item = $result->get('Item') ?: $result->get('Attributes')) { $items = array($item); } else { $items = $result->getPath('Responses/*'); } } return new self(new \ArrayIterator($items ?: array())); } /** * Ensures that the inner iterator is both Traversable and Countable * * {@inheritdoc} * * @throws InvalidArgumentException */ public function __construct(\Traversable $iterator) { if (!($iterator instanceof \Countable)) { throw new InvalidArgumentException('The inner iterator for an ItemIterator must be Countable.'); } parent::__construct($iterator); } /** * Returns the first item in the iterator */ public function getFirst() { $this->rewind(); return $this->current(); } /** * {@inheritdoc} * @return Collection */ public function current() { return new Collection(array_map(array($this, 'processAttribute'), parent::current())); } public function count() { return $this->getInnerIterator()->count(); } public function toArray() { return iterator_to_array($this, false); } /** * Converts an item's attribute from the DynamoDB format to a typeless value in order to simplify the overall * array structure of an item. The method also base64 decodes the value any Binary attributes * * @param array $attribute * * @return array|string */ protected function processAttribute(array $attribute) { list($type, $value) = each($attribute); if ($type === 'B') { $value = base64_decode($value); } elseif ($type === 'BS') { $value = array_map('base64_decode', $value); } return $value; } } sdk-2.5.2/Aws/DynamoDb/Iterator/ScanIterator.php000064411532700161006750000000316112272324172016536 0ustar scannedCount; } /** * {@inheritdoc} */ protected function handleResults(Model $result) { $this->scannedCount += (int) $result->get('ScannedCount'); return parent::handleResults($result); } } sdk-2.5.2/Aws/DynamoDb/Model/Attribute.php000064411532700161006750000001635712272324172015365 0ustar 1) { throw new InvalidArgumentException('Sets must be at most one level deep.'); } // Handle specific, allowed object types if ($value instanceof Attribute) { return $value; } elseif ($value instanceof \Traversable) { $value = iterator_to_array($value); } elseif (is_object($value) && method_exists($value, '__toString')) { $value = (string) $value; } // Ensure that the value is valid if ($value === null || $value === array() || $value === '') { // Note: "Empty" values are not allowed except for zero and false. throw new InvalidArgumentException('The value must not be empty.'); } elseif (is_resource($value) || is_object($value)) { throw new InvalidArgumentException('The value must be able to be converted to string.'); } // Create the attribute to return if (is_int($value) || is_float($value)) { // Handle numeric values $attribute = new Attribute((string) $value, Type::NUMBER); } elseif (is_bool($value)) { // Handle boolean values $attribute = new Attribute($value ? '1' : '0', Type::NUMBER); } elseif (is_array($value) || $value instanceof \Traversable) { // Handle arrays $setType = null; $attribute = new Attribute(array()); // Loop through each value to analyze and prepare it foreach ($value as $subValue) { // Recursively get the attribute for the set. The depth param only allows one level of recursion $subAttribute = static::factory($subValue, $depth + 1); // The type of each sub-value must be the same, or else the whole array is invalid if ($setType === null) { $setType = $subAttribute->type; } elseif ($setType !== $subAttribute->type) { throw new InvalidArgumentException('The set did not contain values of a uniform type.'); } // Save the value for the upstream array $attribute->value[] = (string) $subAttribute->value; } // Make sure the type is changed to be a set type $attribute->type = $setType . self::SET_SUFFIX; } else { $attribute = new Attribute((string) $value); } return $attribute; } /** * Instantiates a DynamoDB attribute. * * @param string|array $value The DynamoDB attribute value * @param string $type The DynamoDB attribute type (N, S, B, NS, SS, BS) */ public function __construct($value, $type = Type::STRING) { $this->setValue($value); $this->setType($type); } /** * Convert the attribute to a string * * @return string */ public function __toString() { return implode(', ', (array) $this->value); } /** * Retrieve the formatted data * * @param string $format The format to apply to the data * * @return string The formatted version of the data */ public function getFormatted($format = Attribute::FORMAT_PUT) { switch ($format) { case self::FORMAT_EXPECTED: // no break case self::FORMAT_UPDATE: $formatted = array('Value' => array($this->type => $this->value)); break; case self::FORMAT_PUT: // no break default: $formatted = array($this->type => $this->value); } return $formatted; } /** * Retrieve the attribute type * * @return string The attribute type */ public function getType() { return $this->type; } /** * Retrieve the attribute value * * @return string The attribute value */ public function getValue() { return $this->value; } /** * Set the attribute type * * @param string $type The attribute type to set * * @return self * @throws InvalidArgumentException */ public function setType($type) { if (in_array($type, Type::values())) { $this->type = $type; } else { throw new InvalidArgumentException('An attribute type must be a valid DynamoDB type.'); } return $this; } /** * Set the attribute value * * @param string|array $value The attribute value * * @return self * @throws InvalidArgumentException */ public function setValue($value) { if (is_string($value) || is_array($value)) { $this->value = $value; } else { throw new InvalidArgumentException('An attribute value may only be a string or array.'); } return $this; } /** * {@inheritdoc} */ public function toArray() { return $this->getFormatted(); } } sdk-2.5.2/Aws/DynamoDb/Model/Item.php000064411532700161006750000001302512272324172014305 0ustar data; foreach ($result as &$value) { if ($value instanceof Attribute) { $value = $value->toArray(); } } return $result; } /** * Construct a new Item * * @param array $attributes Array of attributes * @param string $tableName Table of the item (if known) */ public function __construct(array $attributes = array(), $tableName = null) { $this->replace($attributes); $this->tableName = $tableName; } /** * Set the name of the table associated with the item * * @param string $tableName Table name * * @return self */ public function setTableName($tableName) { $this->tableName = $tableName; return $this; } /** * Get the name of the table associated with the item * * @return string|null */ public function getTableName() { return $this->tableName; } /** * Get an attribute object by name * * @param string $name Name of the attribute to retrieve * * @return Attribute|null */ public function get($name) { return isset($this->data[$name]) ? $this->data[$name] : null; } /** * Get all of the attribute names of the item * * @return array */ public function keys() { return array_keys($this->data); } /** * Check if a particular attribute exists on the item * * @param string $attribute Attribute name to check * * @return bool */ public function has($attribute) { return isset($this->data[$attribute]); } /** * Get all of the {@see Attribute} objects * * @return array */ public function all() { return $this->data; } /** * Add an attribute * * @param string $name Name of the attribute to add * @param Attribute $attribute Attribute to add * * @return self */ public function add($name, Attribute $attribute) { $this->data[$name] = $attribute; return $this; } /** * Set all of the attributes * * @param array $attributes Array of {@see Attribute} objects * * @return self */ public function replace(array $attributes) { foreach ($attributes as $name => $attribute) { if (!($attribute instanceof Attribute)) { $attribute = new Attribute(current($attribute), key($attribute)); } $this->add($name, $attribute); } return $this; } /** * Remove an attribute by name * * @param string $name Name of the attribute to remove * * @return self */ public function remove($name) { unset($this->data[$name]); return $this; } /** * Get the total number of attributes * * @return int */ public function count() { return count($this->data); } /** * {@inheritdoc} */ public function getIterator() { return new \ArrayIterator($this->data); } /** * ArrayAccess implementation of offsetExists() * * @param string $offset Array key * * @return bool */ public function offsetExists($offset) { return isset($this->data[$offset]); } /** * ArrayAccess implementation of offsetGet() * * @param string $offset Array key * * @return null|mixed */ public function offsetGet($offset) { return isset($this->data[$offset]) ? $this->data[$offset] : null; } /** * ArrayAccess implementation of offsetGet() * * @param string $offset Array key * @param mixed $value Value to set */ public function offsetSet($offset, $value) { $this->data[$offset] = $value; } /** * ArrayAccess implementation of offsetUnset() * * @param string $offset Array key */ public function offsetUnset($offset) { unset($this->data[$offset]); } } sdk-2.5.2/Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.php000064411532700161006750000000175012272324172022132 0ustar tableName; } } sdk-2.5.2/Aws/DynamoDb/Model/BatchRequest/DeleteRequest.php000064411532700161006750000000477612272324172020571 0ustar getName() !== 'DeleteItem') { throw new InvalidArgumentException(); } // Get relevant data for a DeleteRequest $table = $command->get('TableName'); $key = $command->get('Key'); // Return an instantiated DeleteRequest object return new DeleteRequest($key, $table); } /** * Constructs a new delete request * * @param array $key The key of the item to delete * @param string $tableName The name of the table which has the item */ public function __construct(array $key, $tableName) { $this->key = $key; $this->tableName = $tableName; } /** * The parameter form of the request * * @return array */ public function toArray() { $key = $this->key; foreach ($key as &$element) { if ($element instanceof Attribute) { $element = $element->toArray(); } } return array('DeleteRequest' => array('Key' => $key)); } /** * Get the key * * @return array */ public function getKey() { return $this->key; } } sdk-2.5.2/Aws/DynamoDb/Model/BatchRequest/PutRequest.php000064411532700161006750000000534612272324172020131 0ustar getName() !== 'PutItem') { throw new InvalidArgumentException(); } // Get relevant data for a PutRequest $table = $command->get('TableName'); $item = $command->get('Item'); // Create an Item object from the 'item' command data if (!($item instanceof Item)) { $item = new Item($item, $table); } // Return an instantiated PutRequest object return new PutRequest($item, $table); } /** * Constructs a new put request * * @param Item $item The item to put into DynamoDB * @param string $tableName The name of the table which has the item * * @throw InvalidArgumentException if the table name is not provided */ public function __construct(Item $item, $tableName = null) { $this->item = $item; $this->tableName = $tableName ?: $item->getTableName(); if (!$this->tableName) { throw new InvalidArgumentException('A table name is required to create a PutRequest.'); } } /** * The parameter form of the request * * @return array */ public function toArray() { return array('PutRequest' => array('Item' => $this->item->toArray())); } /** * Get the item * * @return Item */ public function getItem() { return $this->item; } } sdk-2.5.2/Aws/DynamoDb/Model/BatchRequest/UnprocessedRequest.php000064411532700161006750000000241212272324172021642 0ustar data = $data; $this->tableName = $tableName; } /** * The parameter form of the request * * @return array */ public function toArray() { return $this->data; } } sdk-2.5.2/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatch.php000064411532700161006750000001044512272324172021411 0ustar createBatchesWith(new BatchSizeDivisor($batchSize)) ->transferWith(new WriteRequestBatchTransfer($client)); if ($notify) { $builder->notify($notify); } $batch = new self($builder->build()); $batch = new FlushingBatch($batch, $batchSize); return $batch; } /** * {@inheritdoc} */ public function add($item) { if ($item instanceof AbstractCommand) { // Convert PutItem and DeleteItem into the correct format $name = $item->getName(); if (in_array($name, array('PutItem', 'DeleteItem'))) { $class = __NAMESPACE__ . '\\' . str_replace('Item', 'Request', $name); $item = $class::fromCommand($item); } else { throw new InvalidArgumentException('The command provided was not a PutItem or DeleteItem command.'); } } if (!($item instanceof WriteRequestInterface)) { throw new InvalidArgumentException('The item are are trying to add to the batch queue is invalid.'); } return $this->decoratedBatch->add($item); } /** * {@inheritdoc} */ public function flush() { // Flush the queue $items = array(); while (!$this->decoratedBatch->isEmpty()) { try { $items = array_merge($items, $this->decoratedBatch->flush()); } catch (BatchTransferException $e) { $unprocessed = $e->getPrevious(); if ($unprocessed instanceof UnprocessedWriteRequestsException) { // Handles the UnprocessedItemsException that may occur for // throttled items the batch. These are re-queued here foreach ($unprocessed as $unprocessedItem) { $this->add($unprocessedItem); } } else { // Re-throw the exception if not handled throw $e; } } } return $items; } } sdk-2.5.2/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.php000064411532700161006750000001654312272324172023123 0ustar client = $client; } /** * {@inheritdoc} */ public function transfer(array $batch) { // Create a container exception for any unprocessed items $unprocessed = new UnprocessedWriteRequestsException(); // Execute the transfer logic $this->performTransfer($batch, $unprocessed); // Throw an exception containing the unprocessed items if there are any if (count($unprocessed)) { throw $unprocessed; } } /** * Transfer a batch of requests and collect any unprocessed items * * @param array $batch A batch of write requests * @param UnprocessedWriteRequestsException $unprocessedRequests Collection of unprocessed items * * @throws \Guzzle\Common\Exception\ExceptionCollection */ protected function performTransfer( array $batch, UnprocessedWriteRequestsException $unprocessedRequests ) { // Do nothing if the batch is empty if (empty($batch)) { return; } // Chunk the array and prepare a set of parallel commands $commands = array(); foreach (array_chunk($batch, self::BATCH_WRITE_MAX_SIZE) as $chunk) { // Convert the request items into the format required by the client $items = array(); foreach ($chunk as $item) { if ($item instanceof AbstractWriteRequest) { /** @var $item AbstractWriteRequest */ $table = $item->getTableName(); if (!isset($items[$table])) { $items[$table] = array(); } $items[$table][] = $item->toArray(); } } // Create the BatchWriteItem request $commands[] = $this->client->getCommand('BatchWriteItem', array( 'RequestItems' => $items, Ua::OPTION => Ua::BATCH )); } // Execute the commands and handle exceptions try { $commands = $this->client->execute($commands); $this->getUnprocessedRequestsFromCommands($commands, $unprocessedRequests); } catch (ExceptionCollection $exceptions) { // Create a container exception for any unhandled (true) exceptions $unhandledExceptions = new ExceptionCollection(); // Loop through caught exceptions and handle RequestTooLarge scenarios /** @var $e DynamoDbException */ foreach ($exceptions as $e) { if ($e instanceof DynamoDbException && $e->getStatusCode() === 413) { $request = $e->getResponse()->getRequest(); $this->retryLargeRequest($request, $unprocessedRequests); } else { $unhandledExceptions->add($e); } } // If there were unhandled exceptions, throw them if (count($unhandledExceptions)) { throw $unhandledExceptions; } } } /** * Handles unprocessed items from the executed commands. Unprocessed items * can be collected and thrown in an UnprocessedWriteRequestsException * * @param array $commands Array of commands * @param UnprocessedWriteRequestsException $unprocessedRequests Collection of unprocessed items */ protected function getUnprocessedRequestsFromCommands( array $commands, UnprocessedWriteRequestsException $unprocessedRequests ) { /** @var $command CommandInterface */ foreach ($commands as $command) { if ($command instanceof CommandInterface && $command->isExecuted()) { $result = $command->getResult(); $items = $this->convertResultsToUnprocessedRequests($result['UnprocessedItems']); foreach ($items as $request) { $unprocessedRequests->addItem($request); } } } } /** * Handles exceptions caused by the request being too large (over 1 MB). The * response will have a status code of 413. In this case the batch should be * split up into smaller batches and retried. * * @param EntityEnclosingRequestInterface $request The failed request * @param UnprocessedWriteRequestsException $unprocessedRequests Collection of unprocessed items */ protected function retryLargeRequest( EntityEnclosingRequestInterface $request, UnprocessedWriteRequestsException $unprocessedRequests ) { // Collect the items out from the request object $items = json_decode($request->getBody(true), true); $items = $this->convertResultsToUnprocessedRequests($items['RequestItems']); // Divide batch into smaller batches and transfer them via recursion // NOTE: Dividing the batch into 3 (instead of 2) batches resulted in less recursion during testing if ($items) { $newBatches = array_chunk($items, ceil(count($items) / 3)); foreach ($newBatches as $newBatch) { $this->performTransfer($newBatch, $unprocessedRequests); } } } /** * Collects and creates unprocessed request objects from data collected from erroneous cases * * @param array $items Data formatted under "RequestItems" or "UnprocessedItems" keys * * @return array */ protected function convertResultsToUnprocessedRequests(array $items) { $unprocessed = array(); foreach ($items as $table => $requests) { foreach ($requests as $request) { $unprocessed[] = new UnprocessedRequest($request, $table); } } return $unprocessed; } } sdk-2.5.2/Aws/DynamoDb/Model/BatchRequest/WriteRequestInterface.php000064411532700161006750000000167212272324172022272 0ustar '2011-12-05', 'endpointPrefix' => 'dynamodb', 'serviceFullName' => 'Amazon DynamoDB', 'serviceAbbreviation' => 'DynamoDB', 'serviceType' => 'json', 'jsonVersion' => '1.0', 'targetPrefix' => 'DynamoDB_20111205.', 'signatureVersion' => 'v4', 'namespace' => 'DynamoDb', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.sa-east-1.amazonaws.com', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'dynamodb.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'BatchGetItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'BatchGetItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves the attributes for multiple items from multiple tables using their primary keys.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.BatchGetItem', ), 'RequestItems' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'TableName', 'key_pattern' => '/[a-zA-Z0-9_.-]+/', ), 'properties' => array( 'Keys' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'maxItems' => 100, 'items' => array( 'name' => 'Key', 'description' => 'The primary key that uniquely identifies each item in a table. A primary key can be a one attribute (hash) primary key or a two attribute (hash-and-range) primary key.', 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'BatchWriteItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'BatchWriteItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Allows to execute a batch of Put and/or Delete Requests for many tables in a single call. A total of 25 requests are allowed.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.BatchWriteItem', ), 'RequestItems' => array( 'required' => true, 'description' => 'A map of table name to list-of-write-requests. Used as input to the BatchWriteItem API call', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'minItems' => 1, 'maxItems' => 25, 'data' => array( 'shape_name' => 'TableName', 'key_pattern' => '/[a-zA-Z0-9_.-]+/', ), 'items' => array( 'name' => 'WriteRequest', 'description' => 'This structure is a Union of PutRequest and DeleteRequest. It can contain exactly one of PutRequest or DeleteRequest. Never Both. This is enforced in the code.', 'type' => 'object', 'properties' => array( 'PutRequest' => array( 'type' => 'object', 'properties' => array( 'Item' => array( 'required' => true, 'description' => 'The item to put', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'DeleteRequest' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'required' => true, 'description' => 'The item\'s key to be delete', 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateTableOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Adds a new table to your account.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.CreateTable', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table you want to create. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'KeySchema' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'AttributeType' => array( 'required' => true, 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', 'enum' => array( 'S', 'N', 'B', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'AttributeType' => array( 'required' => true, 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', 'enum' => array( 'S', 'N', 'B', ), ), ), ), ), ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'description' => 'ReadCapacityUnits are in terms of strictly consistent reads, assuming items of 1k. 2k items require twice the ReadCapacityUnits. Eventually-consistent reads only require half the ReadCapacityUnits of stirctly consistent reads.', 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'description' => 'WriteCapacityUnits are in terms of strictly consistent reads, assuming items of 1k. 2k items require twice the WriteCapacityUnits.', 'type' => 'numeric', 'minimum' => 1, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'This exception is thrown when the subscriber exceeded the limits on the number of objects or operations.', 'class' => 'LimitExceededException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Deletes a single item in a table by primary key.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.DeleteItem', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to delete an item. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'Allows you to provide an attribute name, and whether or not Amazon DynamoDB should check to see if the attribute value already exists; or if the attribute value exists and has a particular value before changing it.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'description' => 'Specify whether or not a value already exists and has a specific content for the attribute name-value pair.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'description' => 'Specify whether or not a value already exists for the attribute name-value pair.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'NONE', 'ALL_OLD', 'UPDATED_OLD', 'ALL_NEW', 'UPDATED_NEW', ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when an expected value does not match what was found in the system.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteTableOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Deletes a table and all of its items.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.DeleteTable', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table you want to delete. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the subscriber exceeded the limits on the number of objects or operations.', 'class' => 'LimitExceededException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTableOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves information about the table, including the current status of the table, the primary key schema and when the table was created.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.DescribeTable', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table you want to describe. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'GetItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves a set of Attributes for an item that matches the primary key.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.GetItem', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to get an item. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'ListTables' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListTablesOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves a paginated list of table names created by the AWS Account of the caller in the AWS Region (e.g. us-east-1).', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.ListTables', ), 'ExclusiveStartTableName' => array( 'description' => 'The name of the table that starts the list. If you already ran a ListTables operation and received a LastEvaluatedTableName value in the response, use that value here to continue the list.', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'PutItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PutItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Creates a new item, or replaces an old item with a new item (including all the attributes).', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.PutItem', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to put an item. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Item' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'Allows you to provide an attribute name, and whether or not Amazon DynamoDB should check to see if the attribute value already exists; or if the attribute value exists and has a particular value before changing it.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'description' => 'Specify whether or not a value already exists and has a specific content for the attribute name-value pair.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'description' => 'Specify whether or not a value already exists for the attribute name-value pair.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'NONE', 'ALL_OLD', 'UPDATED_OLD', 'ALL_NEW', 'UPDATED_NEW', ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when an expected value does not match what was found in the system.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'Query' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'QueryOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Gets the values of one or more items and its attributes by primary key (composite primary key, only).', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.Query', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to query. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'Limit' => array( 'description' => 'The maximum number of items to return. If Amazon DynamoDB hits this limit while querying the table, it stops the query and returns the matching values up to the limit, and a LastEvaluatedKey to apply in a subsequent operation to continue the query. Also, if the result set size exceeds 1MB before Amazon DynamoDB hits this limit, it stops the query and returns the matching values, and a LastEvaluatedKey to apply in a subsequent operation to continue the query.', 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'Count' => array( 'description' => 'If set to true, Amazon DynamoDB returns a total number of items that match the query parameters, instead of a list of the matching items and their attributes. Do not set Count to true while providing a list of AttributesToGet, otherwise Amazon DynamoDB returns a validation error.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'HashKeyValue' => array( 'required' => true, 'description' => 'Attribute value of the hash component of the composite primary key.', 'type' => 'object', 'location' => 'json', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyCondition' => array( 'description' => 'A container for the attribute values and comparison operators to use for the query.', 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeValueList' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeValue', 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'EQ', 'NE', 'IN', 'LE', 'LT', 'GE', 'GT', 'BETWEEN', 'NOT_NULL', 'NULL', 'CONTAINS', 'NOT_CONTAINS', 'BEGINS_WITH', ), ), ), ), 'ScanIndexForward' => array( 'description' => 'Specifies forward or backward traversal of the index. Amazon DynamoDB returns results reflecting the requested order, determined by the range key. The default value is true (forward).', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'ExclusiveStartKey' => array( 'description' => 'Primary key of the item from which to continue an earlier query. An earlier query might provide this value as the LastEvaluatedKey if that query operation was interrupted before completing the query; either because of the result set size or the Limit parameter. The LastEvaluatedKey can be passed back in a new query request to continue the operation from that point.', 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'Scan' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ScanOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves one or more items and its attributes by performing a full scan of a table.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.Scan', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to scan. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'Limit' => array( 'description' => 'The maximum number of items to return. If Amazon DynamoDB hits this limit while scanning the table, it stops the scan and returns the matching values up to the limit, and a LastEvaluatedKey to apply in a subsequent operation to continue the scan. Also, if the scanned data set size exceeds 1 MB before Amazon DynamoDB hits this limit, it stops the scan and returns the matching values up to the limit, and a LastEvaluatedKey to apply in a subsequent operation to continue the scan.', 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), 'Count' => array( 'description' => 'If set to true, Amazon DynamoDB returns a total number of items for the Scan operation, even if the operation has no matching items for the assigned filter. Do not set Count to true while providing a list of AttributesToGet, otherwise Amazon DynamoDB returns a validation error.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'ScanFilter' => array( 'description' => 'Evaluates the scan results and returns only the desired values.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'String', ), 'properties' => array( 'AttributeValueList' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeValue', 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'EQ', 'NE', 'IN', 'LE', 'LT', 'GE', 'GT', 'BETWEEN', 'NOT_NULL', 'NULL', 'CONTAINS', 'NOT_CONTAINS', 'BEGINS_WITH', ), ), ), ), ), 'ExclusiveStartKey' => array( 'description' => 'Primary key of the item from which to continue an earlier scan. An earlier scan might provide this value if that scan operation was interrupted before scanning the entire table; either because of the result set size or the Limit parameter. The LastEvaluatedKey can be passed back in a new scan request to continue the operation from that point.', 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Edits an existing item\'s attributes.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.UpdateItem', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to update an item. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), 'AttributeUpdates' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'Specifies the attribute to update and how to perform the update. Possible values: PUT (default), ADD or DELETE.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Action' => array( 'type' => 'string', 'enum' => array( 'ADD', 'PUT', 'DELETE', ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'Allows you to provide an attribute name, and whether or not Amazon DynamoDB should check to see if the attribute value already exists; or if the attribute value exists and has a particular value before changing it.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'description' => 'Specify whether or not a value already exists and has a specific content for the attribute name-value pair.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'description' => 'Specify whether or not a value already exists for the attribute name-value pair.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'NONE', 'ALL_OLD', 'UPDATED_OLD', 'ALL_NEW', 'UPDATED_NEW', ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when an expected value does not match what was found in the system.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateTableOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Updates the provisioned throughput for the given table.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.UpdateTable', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table you want to update. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'description' => 'ReadCapacityUnits are in terms of strictly consistent reads, assuming items of 1k. 2k items require twice the ReadCapacityUnits. Eventually-consistent reads only require half the ReadCapacityUnits of stirctly consistent reads.', 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'description' => 'WriteCapacityUnits are in terms of strictly consistent reads, assuming items of 1k. 2k items require twice the WriteCapacityUnits.', 'type' => 'numeric', 'minimum' => 1, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the subscriber exceeded the limits on the number of objects or operations.', 'class' => 'LimitExceededException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), ), 'models' => array( 'BatchGetItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Responses' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'The item attributes from a response in a specific table, along with the read resources consumed on the table during the request.', 'type' => 'object', 'properties' => array( 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'UnprocessedKeys' => array( 'description' => 'Contains a map of tables and their respective keys that were not processed with the current response, possibly due to reaching a limit on the response size. The UnprocessedKeys value is in the same form as a RequestItems parameter (so the value can be provided directly to a subsequent BatchGetItem operation). For more information, see the above RequestItems parameter.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'Keys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'description' => 'The primary key that uniquely identifies each item in a table. A primary key can be a one attribute (hash) primary key or a two attribute (hash-and-range) primary key.', 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', ), ), ), ), ), ), 'BatchWriteItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Responses' => array( 'description' => 'The response object as a result of BatchWriteItem call. This is essentially a map of table name to ConsumedCapacityUnits.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'ConsumedCapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'UnprocessedItems' => array( 'description' => 'The Items which we could not successfully process in a BatchWriteItem call is returned as UnprocessedItems', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'WriteRequest', 'description' => 'This structure is a Union of PutRequest and DeleteRequest. It can contain exactly one of PutRequest or DeleteRequest. Never Both. This is enforced in the code.', 'type' => 'object', 'properties' => array( 'PutRequest' => array( 'type' => 'object', 'properties' => array( 'Item' => array( 'description' => 'The item to put', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), ), 'DeleteRequest' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'description' => 'The item\'s key to be delete', 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), ), ), ), 'CreateTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'description' => 'The name of the table being described.', 'type' => 'string', ), 'KeySchema' => array( 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), 'DeleteItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'description' => 'If the ReturnValues parameter is provided as ALL_OLD in the request, Amazon DynamoDB returns an array of attribute name-value pairs (essentially, the deleted item). Otherwise, the response contains an empty set.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DeleteTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'description' => 'The name of the table being described.', 'type' => 'string', ), 'KeySchema' => array( 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), 'DescribeTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Table' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'description' => 'The name of the table being described.', 'type' => 'string', ), 'KeySchema' => array( 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), 'GetItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Item' => array( 'description' => 'Contains the requested attributes.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'ListTablesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableNames' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TableName', 'type' => 'string', ), ), 'LastEvaluatedTableName' => array( 'description' => 'The name of the last table in the current list. Use this value as the ExclusiveStartTableName in a new request to continue the list until all the table names are returned. If this value is null, all table names have been returned.', 'type' => 'string', 'location' => 'json', ), ), ), 'PutItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'description' => 'Attribute values before the put operation, but only if the ReturnValues parameter is specified as ALL_OLD in the request.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'QueryOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'Count' => array( 'description' => 'Number of items in the response.', 'type' => 'numeric', 'location' => 'json', ), 'LastEvaluatedKey' => array( 'description' => 'Primary key of the item where the query operation stopped, inclusive of the previous result set. Use this value to start a new operation excluding this value in the new request. The LastEvaluatedKey is null when the entire query result set is complete (i.e. the operation processed the "last page").', 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'ScanOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'Count' => array( 'description' => 'Number of items in the response.', 'type' => 'numeric', 'location' => 'json', ), 'ScannedCount' => array( 'description' => 'Number of items in the complete scan before any filters are applied. A high ScannedCount value with few, or no, Count results indicates an inefficient Scan operation.', 'type' => 'numeric', 'location' => 'json', ), 'LastEvaluatedKey' => array( 'description' => 'Primary key of the item where the scan operation stopped. Provide this value in a subsequent scan operation to continue the operation from that point. The LastEvaluatedKey is null when the entire scan result set is complete (i.e. the operation processed the "last page").', 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'UpdateItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'description' => 'A map of attribute name-value pairs, but only if the ReturnValues parameter is specified as something other than NONE in the request.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'UpdateTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'description' => 'The name of the table being described.', 'type' => 'string', ), 'KeySchema' => array( 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 20, 'max_attempts' => 25, ), '__TableState' => array( 'operation' => 'DescribeTable', ), 'TableExists' => array( 'extends' => '__TableState', 'description' => 'Wait until a table exists and can be accessed', 'success.type' => 'output', 'success.path' => 'Table/TableStatus', 'success.value' => 'ACTIVE', 'ignore_errors' => array( 'ResourceNotFoundException', ), ), 'TableNotExists' => array( 'extends' => '__TableState', 'description' => 'Wait until a table is deleted', 'success.type' => 'error', 'success.value' => 'ResourceNotFoundException', ), ), ); sdk-2.5.2/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php000064411532700161006750000057264512272324172017165 0ustar '2012-08-10', 'endpointPrefix' => 'dynamodb', 'serviceFullName' => 'Amazon DynamoDB', 'serviceAbbreviation' => 'DynamoDB', 'serviceType' => 'json', 'jsonVersion' => '1.0', 'targetPrefix' => 'DynamoDB_20120810.', 'signatureVersion' => 'v4', 'namespace' => 'DynamoDb', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'dynamodb.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'BatchGetItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'BatchGetItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.BatchGetItem', ), 'RequestItems' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'TableName', 'key_pattern' => '/[a-zA-Z0-9_.-]+/', ), 'properties' => array( 'Keys' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'maxItems' => 100, 'items' => array( 'name' => 'Key', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'BatchWriteItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'BatchWriteItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.BatchWriteItem', ), 'RequestItems' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'minItems' => 1, 'maxItems' => 25, 'data' => array( 'shape_name' => 'TableName', 'key_pattern' => '/[a-zA-Z0-9_.-]+/', ), 'items' => array( 'name' => 'WriteRequest', 'type' => 'object', 'properties' => array( 'PutRequest' => array( 'type' => 'object', 'properties' => array( 'Item' => array( 'required' => true, 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'DeleteRequest' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'required' => true, 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), ), ), ), ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnItemCollectionMetrics' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', 'class' => 'ItemCollectionSizeLimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateTableOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.CreateTable', ), 'AttributeDefinitions' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'AttributeType' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'KeySchema' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'maxItems' => 2, 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'KeyType' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'LocalSecondaryIndex', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'required' => true, 'type' => 'string', 'minLength' => 3, 'maxLength' => 255, ), 'KeySchema' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'maxItems' => 2, 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'KeyType' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'Projection' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'minItems' => 1, 'maxItems' => 20, 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'GlobalSecondaryIndex', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'required' => true, 'type' => 'string', 'minLength' => 3, 'maxLength' => 255, ), 'KeySchema' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'maxItems' => 2, 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'KeyType' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'Projection' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'minItems' => 1, 'maxItems' => 20, 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), ), ), ), ), ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The operation conflicts with the resource\'s availability. For example, you attempted to recreate an existing table, or tried to delete a table currently in the CREATING state.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'The number of concurrent table requests (cumulative number of tables in the CREATING, DELETING or UPDATING state) exceeds the maximum allowed of 10. Also, for tables with secondary indexes, only one of those tables can be in the CREATING state at any point in time. Do not attempt to create more than one such table simultaneously. The total limit of tables in the ACTIVE state is 250.', 'class' => 'LimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.DeleteItem', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnItemCollectionMetrics' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A condition specified in the operation could not be evaluated.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', 'class' => 'ItemCollectionSizeLimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteTableOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.DeleteTable', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'The operation conflicts with the resource\'s availability. For example, you attempted to recreate an existing table, or tried to delete a table currently in the CREATING state.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The number of concurrent table requests (cumulative number of tables in the CREATING, DELETING or UPDATING state) exceeds the maximum allowed of 10. Also, for tables with secondary indexes, only one of those tables can be in the CREATING state at any point in time. Do not attempt to create more than one such table simultaneously. The total limit of tables in the ACTIVE state is 250.', 'class' => 'LimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTableOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.DescribeTable', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'GetItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.GetItem', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'ListTables' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListTablesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.ListTables', ), 'ExclusiveStartTableName' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'PutItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PutItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.PutItem', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Item' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnItemCollectionMetrics' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A condition specified in the operation could not be evaluated.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', 'class' => 'ItemCollectionSizeLimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'Query' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'QueryOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.Query', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'IndexName' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Select' => array( 'type' => 'string', 'location' => 'json', ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'KeyConditions' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'AttributeValueList' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeValue', 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'ScanIndexForward' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'ExclusiveStartKey' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'Scan' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ScanOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.Scan', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), 'Select' => array( 'type' => 'string', 'location' => 'json', ), 'ScanFilter' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'AttributeValueList' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeValue', 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'ExclusiveStartKey' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'TotalSegments' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 4096, ), 'Segment' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 4095, ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.UpdateItem', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'AttributeUpdates' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Action' => array( 'type' => 'string', ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnItemCollectionMetrics' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A condition specified in the operation could not be evaluated.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', 'class' => 'ItemCollectionSizeLimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateTableOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.UpdateTable', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'ProvisionedThroughput' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), ), ), 'GlobalSecondaryIndexUpdates' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'GlobalSecondaryIndexUpdate', 'type' => 'object', 'properties' => array( 'Update' => array( 'type' => 'object', 'properties' => array( 'IndexName' => array( 'required' => true, 'type' => 'string', 'minLength' => 3, 'maxLength' => 255, ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The operation conflicts with the resource\'s availability. For example, you attempted to recreate an existing table, or tried to delete a table currently in the CREATING state.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The number of concurrent table requests (cumulative number of tables in the CREATING, DELETING or UPDATING state) exceeds the maximum allowed of 10. Also, for tables with secondary indexes, only one of those tables can be in the CREATING state at any point in time. Do not attempt to create more than one such table simultaneously. The total limit of tables in the ACTIVE state is 250.', 'class' => 'LimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), ), 'models' => array( 'BatchGetItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Responses' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), ), 'UnprocessedKeys' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'Keys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ConsumedCapacity', 'type' => 'object', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), ), 'BatchWriteItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UnprocessedItems' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'WriteRequest', 'type' => 'object', 'properties' => array( 'PutRequest' => array( 'type' => 'object', 'properties' => array( 'Item' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), ), 'DeleteRequest' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), ), ), ), ), ), 'ItemCollectionMetrics' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionMetrics', 'type' => 'object', 'properties' => array( 'ItemCollectionKey' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'SizeEstimateRangeGB' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionSizeEstimateBound', 'type' => 'numeric', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ConsumedCapacity', 'type' => 'object', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), ), 'CreateTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeDefinitions' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), ), ), ), 'TableName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'LocalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'GlobalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexStatus' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'DeleteItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), 'ItemCollectionMetrics' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'ItemCollectionKey' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'SizeEstimateRangeGB' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionSizeEstimateBound', 'type' => 'numeric', ), ), ), ), ), ), 'DeleteTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeDefinitions' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), ), ), ), 'TableName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'LocalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'GlobalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexStatus' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'DescribeTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Table' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeDefinitions' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), ), ), ), 'TableName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'LocalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'GlobalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexStatus' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'GetItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Item' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'ListTablesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableNames' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TableName', 'type' => 'string', ), ), 'LastEvaluatedTableName' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'PutItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), 'ItemCollectionMetrics' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'ItemCollectionKey' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'SizeEstimateRangeGB' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionSizeEstimateBound', 'type' => 'numeric', ), ), ), ), ), ), 'QueryOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), 'Count' => array( 'type' => 'numeric', 'location' => 'json', ), 'LastEvaluatedKey' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'ScanOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), 'Count' => array( 'type' => 'numeric', 'location' => 'json', ), 'ScannedCount' => array( 'type' => 'numeric', 'location' => 'json', ), 'LastEvaluatedKey' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'UpdateItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), 'ItemCollectionMetrics' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'ItemCollectionKey' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'SizeEstimateRangeGB' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionSizeEstimateBound', 'type' => 'numeric', ), ), ), ), ), ), 'UpdateTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeDefinitions' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), ), ), ), 'TableName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'LocalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'GlobalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexStatus' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 20, 'max_attempts' => 25, ), '__TableState' => array( 'operation' => 'DescribeTable', ), 'TableExists' => array( 'extends' => '__TableState', 'success.type' => 'output', 'success.path' => 'Table/TableStatus', 'success.value' => 'ACTIVE', 'ignore_errors' => array( 'ResourceNotFoundException', ), ), 'TableNotExists' => array( 'extends' => '__TableState', 'success.type' => 'error', 'success.value' => 'ResourceNotFoundException', ), ), ); sdk-2.5.2/Aws/DynamoDb/Session/SessionHandler.php000064411532700161006750000003742112272324172016721 0ustar get('dynamodb_client'); // Make sure locking strategy has been provided or provide a default $strategy = $config->get('locking_strategy'); if (!($strategy instanceof LockingStrategyInterface)) { $factory = new LockingStrategyFactory(); $strategy = $factory->factory($strategy, $config); } // Return an instance of the session handler return new static($client, $strategy, $config); } /** * Constructs a new DynamoDB Session Handler * * @param DynamoDbClient $client Client for doing DynamoDB operations * @param LockingStrategyInterface $strategy Locking strategy for performing session locking logic * @param SessionHandlerConfig $config Configuration options for the session handler */ public function __construct( DynamoDbClient $client, LockingStrategyInterface $strategy, SessionHandlerConfig $config ) { $this->client = $client; $this->lockingStrategy = $strategy; $this->config = $config; } /** * Destruct the session handler and make sure the session gets written * * NOTE: It is usually better practice to call `session_write_close()` manually in your application as soon as * session modifications are complete. This is especially true if session locking is enabled. * * @link http://php.net/manual/en/function.session-set-save-handler.php#refsect1-function.session-set-save-handler-notes */ public function __destruct() { session_write_close(); } /** * Register the DynamoDB session handler. * * Uses the PHP-provided method to register this class as a session handler. * * @return bool Whether or not the handler was registered */ public function register() { // Set garbage collection probability based on config $autoGarbageCollection = $this->config->get('automatic_gc') ? '1' : '0'; ini_set('session.gc_probability', $autoGarbageCollection); // Register the session handler return session_set_save_handler( array($this, 'open'), array($this, 'close'), array($this, 'read'), array($this, 'write'), array($this, 'destroy'), array($this, 'gc') ); } /** * Checks if the session is open and writable * * @return bool Whether or not the session is open for writing */ public function isSessionOpen() { return (bool) $this->openSessionId; } /** * Checks if the session has been written * * @return bool Whether or not the session has been written */ public function isSessionWritten() { return $this->sessionWritten; } /** * Creates a table in DynamoDB for session storage according to provided configuration options. * * Note: This is a one-time operation. It may be better to do this via the AWS management console ahead of time. * * @param int $readCapacityUnits RCUs for table read throughput * @param int $writeCapacityUnits WCUs table write throughput * * @return array The command result */ public function createSessionsTable($readCapacityUnits, $writeCapacityUnits) { $tableName = $this->config->get('table_name'); $hashKey = $this->config->get('hash_key'); $params = array( 'TableName' => $tableName, 'ProvisionedThroughput' => array( 'ReadCapacityUnits' => (int) $readCapacityUnits, 'WriteCapacityUnits' => (int) $writeCapacityUnits, ), Ua::OPTION => Ua::SESSION ); if ($this->client->getApiVersion() < '2012-08-10') { $params['KeySchema'] = array( 'HashKeyElement' => array( 'AttributeName' => $hashKey, 'AttributeType' => 'S', ) ); } else { $params['AttributeDefinitions'] = array( array( 'AttributeName' => $hashKey, 'AttributeType' => 'S' ) ); $params['KeySchema'] = array( array( 'AttributeName' => $hashKey, 'KeyType' => 'HASH' ) ); } $result = $this->client->getCommand('CreateTable', $params)->execute(); $this->client->waitUntil('table_exists', array('TableName' => $tableName)); return $result; } /** * Open a session for writing. Triggered by session_start() * * Part of the standard PHP session handler interface * * @param string $savePath The session save path * @param string $sessionName The session name * * @return bool Whether or not the operation succeeded */ public function open($savePath, $sessionName) { $this->savePath = $savePath; $this->sessionName = $sessionName; $this->openSessionId = session_id(); return $this->isSessionOpen(); } /** * Close a session from writing * * Part of the standard PHP session handler interface * * @return bool Success */ public function close() { // Make sure the session is unlocked and the expiration time is updated, even if the write did not occur if (!$this->isSessionWritten()) { $id = $this->formatId($this->openSessionId); $result = $this->lockingStrategy->doWrite($id, '', false); $this->sessionWritten = (bool) $result; } $this->openSessionId = null; return $this->isSessionWritten(); } /** * Read a session stored in DynamoDB * * Part of the standard PHP session handler interface * * @param string $id The session ID * * @return string The session data */ public function read($id) { // PHP expects an empty string to be returned from this method if no // data is retrieved $this->dataRead = ''; // Get session data using the selected locking strategy $item = $this->lockingStrategy->doRead($this->formatId($id)); // Return the data if it is not expired. If it is expired, remove it if (isset($item['expires']) && isset($item['data'])) { $this->dataRead = $item['data']; if ($item['expires'] <= time()) { $this->dataRead = ''; $this->destroy($id); } } return $this->dataRead; } /** * Write a session to DynamoDB * * Part of the standard PHP session handler interface * * @param string $id The session ID * @param string $data The serialized session data to write * * @return bool Whether or not the operation succeeded */ public function write($id, $data) { // Write the session data using the selected locking strategy $this->sessionWritten = $this->lockingStrategy->doWrite( $this->formatId($id), $data, ($data !== $this->dataRead) ); return $this->isSessionWritten(); } /** * Delete a session stored in DynamoDB * * Part of the standard PHP session handler interface * * @param string $id The session ID * * @return bool Whether or not the operation succeeded */ public function destroy($id) { // Delete the session data using the selected locking strategy $this->sessionWritten = $this->lockingStrategy->doDestroy($this->formatId($id)); return $this->isSessionWritten(); } /** * Triggers garbage collection on expired sessions * * Part of the standard PHP session handler interface * * @param int $maxLifetime The value of `session.gc_maxlifetime`. Ignored * * @return bool */ public function gc($maxLifetime) { try { $this->garbageCollect(); return true; } catch (\Exception $e) { return false; } } /** * Performs garbage collection on the sessions stored in the DynamoDB table * * If triggering garbage collection manually, use this method. If your garbage collection is triggered automatically * by php (not recommended), then use the `gc` method. */ public function garbageCollect() { // Get relevant configuration data $delay = (int) $this->config->get('gc_operation_delay'); $batchSize = (int) $this->config->get('gc_batch_size'); $tableName = $this->config->get('table_name'); $hashKey = $this->config->get('hash_key'); $expires = (string) time(); $isOldApi = ($this->client->getApiVersion() < '2012-08-10'); // Instantiate and configure the WriteRequestBatch object that will be deleting the expired sessions if ($delay) { $delayFunction = function () use ($delay) { sleep($delay); }; $deleteBatch = WriteRequestBatch::factory($this->client, $batchSize, $delayFunction); } else { $deleteBatch = WriteRequestBatch::factory($this->client, $batchSize); } // Setup a scan table iterator for finding expired session items $scanParams = array( 'TableName' => $tableName, 'AttributesToGet' => array( $this->config->get('hash_key') ), 'ScanFilter' => array( 'expires' => array( 'ComparisonOperator' => 'LT', 'AttributeValueList' => array( array( 'N' => $expires ) ), ), 'lock' => array( 'ComparisonOperator' => 'NULL', ) ), Ua::OPTION => Ua::SESSION ); if (!$isOldApi) { $scanParams['Select'] = 'SPECIFIC_ATTRIBUTES'; } // Create a scan table iterator for finding expired session items $tableScanner = $this->client->getIterator('Scan', $scanParams); // If a delay has been set, then attach the delay function to execute after each scan operation if (isset($delayFunction)) { $tableScanner->getEventDispatcher()->addListener('resource_iterator.after_send', $delayFunction); } // Perform scan and batch delete operations as needed $keyName = $isOldApi ? 'HashKeyElement' : $hashKey; foreach ($tableScanner as $item) { // @codeCoverageIgnoreStart $deleteBatch->add(new DeleteRequest(array($keyName => $item[$hashKey]), $tableName)); // @codeCoverageIgnoreEnd } // Delete any remaining items $deleteBatch->flush(); } /** * Prepend the session ID with the session name * * @param string $id The session ID * * @return string Prepared session ID */ protected function formatId($id) { return trim($this->sessionName . '_' . $id, '_'); } } sdk-2.5.2/Aws/DynamoDb/Session/SessionHandlerConfig.php000064411532700161006750000000505212272324172020042 0ustar data = $data; // Make sure the DynamoDB client has been provided if (!($this->get('dynamodb_client') instanceof DynamoDbClient)) { throw new InvalidArgumentException('The DynamoDB Session Handler ' . 'must be provided an instance of the DynamoDbClient.'); } // Merge provided data with defaults $this->addDefaults(array( 'table_name' => 'sessions', 'hash_key' => 'id', 'session_lifetime' => (int) ini_get('session.gc_maxlifetime'), 'consistent_read' => true, 'automatic_gc' => (bool) ini_get('session.gc_probability'), 'gc_batch_size' => 25, 'gc_operation_delay' => 0, )); } /** * Gets a config value if it exists, otherwise it returns null * * @param string $key The key of the config item * * @return mixed */ public function get($key) { return array_key_exists($key, $this->data) ? $this->data[$key] : null; } /** * Applies default values by merging underneath the current data * * @param array $defaults The new default data to merge underneath * * @return SessionHandlerConfig */ public function addDefaults(array $defaults) { $this->data = array_replace($defaults, $this->data); return $this; } } sdk-2.5.2/Aws/DynamoDb/Session/SessionHandlerInterface.php000064411532700161006750000000107012272324172020531 0ustar = 50400) { /** * @see http://php.net/manual/en/class.sessionhandlerinterface.php */ interface SessionHandlerInterface extends \SessionHandlerInterface {} } else { interface SessionHandlerInterface { public function close(); public function destroy($session_id); public function gc($maxLifetime); public function open($savePath, $sessionName); public function read($sessionId); public function write($sessionId, $sessionData); } } sdk-2.5.2/Aws/DynamoDb/Session/LockingStrategy/AbstractLockingStrategy.php000064411532700161006750000000744012272324172023704 0ustar client = $client; $this->config = $config; } /** * {@inheritdoc} */ public function doWrite($id, $data, $isDataChanged) { // Prepare the attributes $expires = time() + $this->config->get('session_lifetime'); $attributes = array( 'expires' => array( 'Value' => array( 'N' => (string) $expires ) ) ); if ($isDataChanged) { if ($data != '') { $attributes['data'] = array( 'Value' => array( 'S' => $data ) ); } else { $attributes['data'] = array( 'Action' => 'DELETE' ); } } $attributes = array_merge($attributes, $this->getExtraAttributes()); // Perform the UpdateItem command try { return (bool) $this->client->getCommand('UpdateItem', array( 'TableName' => $this->config->get('table_name'), 'Key' => $this->formatKey($id), 'AttributeUpdates' => $attributes, Ua::OPTION => Ua::SESSION ))->execute(); } catch (DynamoDbException $e) { return false; } } /** * {@inheritdoc} */ public function doDestroy($id) { try { return (bool) $this->client->getCommand('DeleteItem', array( 'TableName' => $this->config->get('table_name'), 'Key' => $this->formatKey($id), Ua::OPTION => Ua::SESSION ))->execute(); } catch (DynamoDbException $e) { return false; } } /** * Generates the correct key structure based on the key value and DynamoDB API version * * @param string $keyValue The value of the key (i.e., the session ID) * * @return array formatted key structure */ protected function formatKey($keyValue) { $keyName = ($this->client->getApiVersion() < '2012-08-10') ? 'HashKeyElement' : $this->config->get('hash_key'); return array($keyName => array('S' => $keyValue)); } /** * Allows the specific strategy to add additional attributes to update * * @return array */ abstract protected function getExtraAttributes(); } sdk-2.5.2/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactory.php000064411532700161006750000000572212272324172023551 0ustar baseNamespace = $baseNamespace ?: __NAMESPACE__; $this->inflector = $inflector ?: Inflector::getDefault(); } /** * Creates a session handler locking strategy * * @param string $lockingStrategy The name if the locking strategy * @param SessionHandlerConfig $config The session handler config data * * @return LockingStrategyInterface * * @throws InvalidArgumentException If the locking strategy doesn't exist */ public function factory($lockingStrategy = null, SessionHandlerConfig $config = null) { // If the locking strategy is null, let's give it the name "null" if ($lockingStrategy === null) { $lockingStrategy = 'null'; } // Make sure the locking strategy name provided is a string if (!is_string($lockingStrategy)) { throw new InvalidArgumentException('The session locking strategy ' . 'name must be provided as a string.'); } // Determine the class name of the locking strategy class $classPath = $this->baseNamespace . '\\' . $this->inflector->camel($lockingStrategy) . 'LockingStrategy'; // Make sure the locking strategy class exists if (!class_exists($classPath)) { throw new InvalidArgumentException("There is no session locking " . "strategy named \"{$classPath}\"."); } // Call the factory on the locking strategy class to create it return new $classPath($config->get('dynamodb_client'), $config); } } sdk-2.5.2/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryInterface.php000064411532700161006750000000231412272324172025364 0ustar client->getCommand('GetItem', array( 'TableName' => $this->config->get('table_name'), 'Key' => $this->formatKey($id), 'ConsistentRead' => (bool) $this->config->get('consistent_read'), Ua::OPTION => Ua::SESSION ))->execute(); // Get the item values $item = array(); $result = isset($result['Item']) ? $result['Item'] : array(); foreach ($result as $key => $value) { $item[$key] = current($value); } } catch (DynamoDbException $e) { $item = array(); } return $item; } /** * {@inheritdoc} */ protected function getExtraAttributes() { // @codeCoverageIgnoreStart return array(); // @codeCoverageIgnoreEnd } } sdk-2.5.2/Aws/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategy.php000064411532700161006750000000754412272324172024442 0ustar addDefaults(array( 'max_lock_wait_time' => 10, 'min_lock_retry_microtime' => 10000, 'max_lock_retry_microtime' => 50000, )); parent::__construct($client, $config); } /** * {@inheritdoc} * Retries the request until the lock can be acquired */ public function doRead($id) { $item = array(); $rightNow = time(); $timeout = $rightNow + $this->config->get('max_lock_wait_time'); // Create an UpdateItem command so that a lock can be set and the item // returned (via ReturnValues) in a single, atomic operation $updateItem = $this->client->getCommand('UpdateItem', array( 'TableName' => $this->config->get('table_name'), 'Key' => $this->formatKey($id), 'Expected' => array( 'lock' => array( 'Exists' => false ) ), 'AttributeUpdates' => array( 'lock' => array( 'Value' => array( 'N' => '1' ) ) ), 'ReturnValues' => 'ALL_NEW', Ua::OPTION => Ua::SESSION )); // Acquire the lock and fetch the item data do { try { $result = $updateItem->execute(); } catch (ConditionalCheckFailedException $e) { // If lock fails, sleep and try again later usleep(rand( $this->config->get('min_lock_retry_microtime'), $this->config->get('max_lock_retry_microtime') )); $result = array(); $rightNow = time(); } catch (DynamoDbException $e) { return $item; } } while (!$result && $rightNow < $timeout); // Get the item attributes if (isset($result['Attributes'])) { foreach ($result['Attributes'] as $key => $value) { $item[$key] = current($value); } } return $item; } /** * {@inheritdoc} */ protected function getExtraAttributes() { // @codeCoverageIgnoreStart return array('lock' => array('Action' => 'DELETE')); // @codeCoverageIgnoreEnd } } sdk-2.5.2/Aws/Ec2/Ec2Client.php000064411532700161006750000006237412272324172013046 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/ec2-%s.php' )) ->build(); } } sdk-2.5.2/Aws/Ec2/Enum/ContainerFormat.php000064411532700161006750000000136312272324172015264 0ustar get('Reservations') as $reservation) { foreach ($reservation['Instances'] as $instance) { $instance['Reservation'] = $reservation; unset($instance['Reservation']['Instances']); $instances[] = $instance; } } return $instances; } } sdk-2.5.2/Aws/Ec2/Resources/ec2-2013-10-15.php000064411532700161006750000247165712272324172014757 0ustar '2013-10-15', 'endpointPrefix' => 'ec2', 'serviceFullName' => 'Amazon Elastic Compute Cloud', 'serviceAbbreviation' => 'Amazon EC2', 'serviceType' => 'query', 'signatureVersion' => 'v2', 'namespace' => 'Ec2', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'ec2.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'ActivateLicense' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ActivateLicense', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Capacity' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'AllocateAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AllocateAddressResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AllocateAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Domain' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AssignPrivateIpAddresses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssignPrivateIpAddresses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PrivateIpAddress', 'items' => array( 'name' => 'PrivateIpAddress', 'type' => 'string', ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AllowReassignment' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'AssociateAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssociateAddressResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssociateAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PublicIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllocationId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PrivateIpAddress' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowReassociation' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'AssociateDhcpOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssociateDhcpOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DhcpOptionsId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AssociateRouteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssociateRouteTableResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssociateRouteTable', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SubnetId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AttachInternetGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachInternetGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InternetGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AttachNetworkInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AttachNetworkInterfaceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachNetworkInterface', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DeviceIndex' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'AttachVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'attachment', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Device' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AttachVpnGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AttachVpnGatewayResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachVpnGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AuthorizeSecurityGroupEgress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeSecurityGroupEgress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpProtocol' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FromPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ToPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CidrIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpPermissions' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'IpPermission', 'type' => 'object', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', ), 'FromPort' => array( 'type' => 'numeric', ), 'ToPort' => array( 'type' => 'numeric', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'Groups', 'items' => array( 'name' => 'Groups', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IpRange', 'type' => 'object', 'properties' => array( 'CidrIp' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'AuthorizeSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'GroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpProtocol' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FromPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ToPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CidrIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpPermissions' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'IpPermission', 'type' => 'object', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', ), 'FromPort' => array( 'type' => 'numeric', ), 'ToPort' => array( 'type' => 'numeric', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'Groups', 'items' => array( 'name' => 'Groups', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IpRange', 'type' => 'object', 'properties' => array( 'CidrIp' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'BundleInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'BundleInstanceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'BundleInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Storage' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'S3' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), 'AWSAccessKeyId' => array( 'type' => 'string', ), 'UploadPolicy' => array( 'type' => 'string', ), 'UploadPolicySignature' => array( 'type' => 'string', ), ), ), ), ), ), ), 'CancelBundleTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CancelBundleTaskResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelBundleTask', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'BundleId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CancelConversionTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelConversionTask', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ConversionTaskId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReasonMessage' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CancelExportTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelExportTask', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ExportTaskId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CancelReservedInstancesListing' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CancelReservedInstancesListingResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelReservedInstancesListing', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ReservedInstancesListingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CancelSpotInstanceRequests' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CancelSpotInstanceRequestsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelSpotInstanceRequests', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SpotInstanceRequestIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SpotInstanceRequestId', 'items' => array( 'name' => 'SpotInstanceRequestId', 'type' => 'string', ), ), ), ), 'ConfirmProductInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfirmProductInstanceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ConfirmProductInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ProductCode' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CopyImage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CopyImageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CopyImage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SourceRegion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClientToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CopySnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CopySnapshotResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CopySnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SourceRegion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceSnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateCustomerGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateCustomerGatewayResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCustomerGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PublicIp' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'sentAs' => 'IpAddress', ), 'BgpAsn' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'CreateDhcpOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateDhcpOptionsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDhcpOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DhcpConfigurations' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DhcpConfiguration', 'items' => array( 'name' => 'DhcpConfiguration', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'CreateImage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateImageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateImage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NoReboot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'VolumeType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), ), ), 'CreateInstanceExportTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateInstanceExportTaskResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateInstanceExportTask', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TargetEnvironment' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ExportToS3Task' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'ExportToS3', 'properties' => array( 'DiskImageFormat' => array( 'type' => 'string', ), 'ContainerFormat' => array( 'type' => 'string', ), 'S3Bucket' => array( 'type' => 'string', ), 'S3Prefix' => array( 'type' => 'string', ), ), ), ), ), 'CreateInternetGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateInternetGatewayResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateInternetGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'CreateKeyPair' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateKeyPairResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateKeyPair', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'KeyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateNetworkAcl' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateNetworkAclResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateNetworkAcl', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateNetworkAclEntry' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateNetworkAclEntry', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'Protocol' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleAction' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Egress' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'IcmpTypeCode' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Icmp', 'properties' => array( 'Type' => array( 'type' => 'numeric', ), 'Code' => array( 'type' => 'numeric', ), ), ), 'PortRange' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'From' => array( 'type' => 'numeric', ), 'To' => array( 'type' => 'numeric', ), ), ), ), ), 'CreateNetworkInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateNetworkInterfaceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateNetworkInterface', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'SubnetId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PrivateIpAddress' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Groups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'PrivateIpAddressSpecification', 'type' => 'object', 'properties' => array( 'PrivateIpAddress' => array( 'required' => true, 'type' => 'string', ), 'Primary' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'CreatePlacementGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreatePlacementGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Strategy' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateReservedInstancesListing' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateReservedInstancesListingResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateReservedInstancesListing', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ReservedInstancesId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'PriceSchedules' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'PriceScheduleSpecification', 'type' => 'object', 'properties' => array( 'Term' => array( 'type' => 'numeric', ), 'Price' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), ), ), ), 'ClientToken' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'GatewayId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateRouteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateRouteTableResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateRouteTable', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateSecurityGroupResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'sentAs' => 'GroupDescription', ), 'VpcId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'snapshot', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateSpotDatafeedSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateSpotDatafeedSubscriptionResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSpotDatafeedSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Prefix' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateSubnet' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateSubnetResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSubnet', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Resources' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ResourceId', 'items' => array( 'name' => 'ResourceId', 'type' => 'string', ), ), 'Tags' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tag', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), 'CreateVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'volume', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Size' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VolumeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'CreateVpc' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateVpcResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVpc', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceTenancy' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateVpnConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateVpnConnectionResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVpnConnection', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CustomerGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpnGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Options' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'StaticRoutesOnly' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'CreateVpnConnectionRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVpnConnectionRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'VpnConnectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateVpnGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateVpnGatewayResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVpnGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeactivateLicense' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeactivateLicense', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Capacity' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'DeleteCustomerGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCustomerGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CustomerGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteDhcpOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDhcpOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DhcpOptionsId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteInternetGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteInternetGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InternetGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteKeyPair' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteKeyPair', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'KeyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteNetworkAcl' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteNetworkAcl', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteNetworkAclEntry' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteNetworkAclEntry', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'Egress' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DeleteNetworkInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteNetworkInterface', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeletePlacementGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeletePlacementGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteRouteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRouteTable', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'GroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteSpotDatafeedSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSpotDatafeedSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DeleteSubnet' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSubnet', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SubnetId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Resources' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ResourceId', 'items' => array( 'name' => 'ResourceId', 'type' => 'string', ), ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tag', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), 'DeleteVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVpc' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVpc', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVpnConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVpnConnection', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnConnectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVpnConnectionRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVpnConnectionRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'VpnConnectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVpnGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVpnGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeregisterImage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeregisterImage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeAccountAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAccountAttributesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAccountAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AttributeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AttributeName', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), ), ), 'DescribeAddresses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAddressesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAddresses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PublicIps' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PublicIp', 'items' => array( 'name' => 'PublicIp', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'AllocationIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AllocationId', 'items' => array( 'name' => 'AllocationId', 'type' => 'string', ), ), ), ), 'DescribeAvailabilityZones' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAvailabilityZonesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAvailabilityZones', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ZoneNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ZoneName', 'items' => array( 'name' => 'ZoneName', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeBundleTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeBundleTasksResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeBundleTasks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'BundleIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BundleId', 'items' => array( 'name' => 'BundleId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeConversionTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeConversionTasksResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeConversionTasks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'ConversionTaskIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ConversionTaskId', 'items' => array( 'name' => 'ConversionTaskId', 'type' => 'string', ), ), ), ), 'DescribeCustomerGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeCustomerGatewaysResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCustomerGateways', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CustomerGatewayIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CustomerGatewayId', 'items' => array( 'name' => 'CustomerGatewayId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeDhcpOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeDhcpOptionsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDhcpOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DhcpOptionsIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DhcpOptionsId', 'items' => array( 'name' => 'DhcpOptionsId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeExportTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeExportTasksResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeExportTasks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ExportTaskIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ExportTaskId', 'items' => array( 'name' => 'ExportTaskId', 'type' => 'string', ), ), ), ), 'DescribeImageAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'imageAttribute', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeImageAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeImages' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeImagesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeImages', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ImageId', 'items' => array( 'name' => 'ImageId', 'type' => 'string', ), ), 'Owners' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Owner', 'items' => array( 'name' => 'Owner', 'type' => 'string', ), ), 'ExecutableUsers' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ExecutableBy', 'items' => array( 'name' => 'ExecutableBy', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeInstanceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'InstanceAttribute', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInstanceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeInstanceStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeInstanceStatusResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInstanceStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'IncludeAllInstances' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DescribeInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'DescribeInternetGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeInternetGatewaysResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInternetGateways', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InternetGatewayIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InternetGatewayId', 'items' => array( 'name' => 'InternetGatewayId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeKeyPairs' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeKeyPairsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeKeyPairs', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'KeyNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'KeyName', 'items' => array( 'name' => 'KeyName', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeLicenses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeLicensesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLicenses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LicenseId', 'items' => array( 'name' => 'LicenseId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeNetworkAcls' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeNetworkAclsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeNetworkAcls', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NetworkAclId', 'items' => array( 'name' => 'NetworkAclId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeNetworkInterfaceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeNetworkInterfaceAttributeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeNetworkInterfaceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceDestCheck' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Groups' => array( 'type' => 'string', 'location' => 'aws.query', 'sentAs' => 'GroupSet', ), 'Attachment' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeNetworkInterfaces' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeNetworkInterfacesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeNetworkInterfaces', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NetworkInterfaceId', 'items' => array( 'name' => 'NetworkInterfaceId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribePlacementGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribePlacementGroupsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribePlacementGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'GroupName', 'items' => array( 'name' => 'GroupName', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeRegions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeRegionsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeRegions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RegionNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'RegionName', 'items' => array( 'name' => 'RegionName', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeReservedInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeReservedInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ReservedInstancesIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesId', 'items' => array( 'name' => 'ReservedInstancesId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeReservedInstancesListings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeReservedInstancesListingsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedInstancesListings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ReservedInstancesId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ReservedInstancesListingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeReservedInstancesModifications' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeReservedInstancesModificationsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedInstancesModifications', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ReservedInstancesModificationIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesModificationId', 'items' => array( 'name' => 'ReservedInstancesModificationId', 'type' => 'string', ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeReservedInstancesOfferings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeReservedInstancesOfferingsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedInstancesOfferings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ReservedInstancesOfferingIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesOfferingId', 'items' => array( 'name' => 'ReservedInstancesOfferingId', 'type' => 'string', ), ), 'InstanceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'InstanceTenancy' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'IncludeMarketplace' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'MinDuration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxDuration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxInstanceCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'DescribeRouteTables' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeRouteTablesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeRouteTables', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'RouteTableId', 'items' => array( 'name' => 'RouteTableId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeSecurityGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSecurityGroupsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSecurityGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'GroupName', 'items' => array( 'name' => 'GroupName', 'type' => 'string', ), ), 'GroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'GroupId', 'items' => array( 'name' => 'GroupId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeSnapshotAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSnapshotAttributeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSnapshotAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeSnapshots' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSnapshotsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSnapshots', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SnapshotId', 'items' => array( 'name' => 'SnapshotId', 'type' => 'string', ), ), 'OwnerIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Owner', 'items' => array( 'name' => 'Owner', 'type' => 'string', ), ), 'RestorableByUserIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'RestorableBy', 'items' => array( 'name' => 'RestorableBy', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeSpotDatafeedSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSpotDatafeedSubscriptionResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSpotDatafeedSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DescribeSpotInstanceRequests' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSpotInstanceRequestsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSpotInstanceRequests', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SpotInstanceRequestIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SpotInstanceRequestId', 'items' => array( 'name' => 'SpotInstanceRequestId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeSpotPriceHistory' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSpotPriceHistoryResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSpotPriceHistory', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'InstanceTypes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceType', 'items' => array( 'name' => 'InstanceType', 'type' => 'string', ), ), 'ProductDescriptions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ProductDescription', 'items' => array( 'name' => 'ProductDescription', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeSubnets' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSubnetsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSubnets', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetId', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeTagsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeVolumeAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVolumeAttributeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVolumeAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeVolumeStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVolumeStatusResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVolumeStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VolumeId', 'items' => array( 'name' => 'VolumeId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'DescribeVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVolumesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVolumes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VolumeId', 'items' => array( 'name' => 'VolumeId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeVpcAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVpcAttributeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVpcAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeVpcs' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVpcsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVpcs', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcId', 'items' => array( 'name' => 'VpcId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeVpnConnections' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVpnConnectionsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVpnConnections', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnConnectionIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpnConnectionId', 'items' => array( 'name' => 'VpnConnectionId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeVpnGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVpnGatewaysResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVpnGateways', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnGatewayIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpnGatewayId', 'items' => array( 'name' => 'VpnGatewayId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DetachInternetGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachInternetGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InternetGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DetachNetworkInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachNetworkInterface', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AttachmentId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Force' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DetachVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'attachment', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Device' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Force' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DetachVpnGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachVpnGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DisableVgwRoutePropagation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableVgwRoutePropagation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'GatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DisassociateAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisassociateAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PublicIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AssociationId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DisassociateRouteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisassociateRouteTable', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AssociationId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'EnableVgwRoutePropagation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableVgwRoutePropagation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'GatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'EnableVolumeIO' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableVolumeIO', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetConsoleOutput' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetConsoleOutputResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetConsoleOutput', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetPasswordData' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetPasswordDataResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetPasswordData', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ImportInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ImportInstanceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ImportInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LaunchSpecification' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Architecture' => array( 'type' => 'string', ), 'GroupNames' => array( 'type' => 'array', 'sentAs' => 'GroupName', 'items' => array( 'name' => 'GroupName', 'type' => 'string', ), ), 'AdditionalInfo' => array( 'type' => 'string', ), 'UserData' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'Placement' => array( 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'Tenancy' => array( 'type' => 'string', ), ), ), 'Monitoring' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'SubnetId' => array( 'type' => 'string', ), 'InstanceInitiatedShutdownBehavior' => array( 'type' => 'string', ), 'PrivateIpAddress' => array( 'type' => 'string', ), ), ), 'DiskImages' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DiskImage', 'items' => array( 'name' => 'DiskImage', 'type' => 'object', 'properties' => array( 'Image' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'required' => true, 'type' => 'string', ), 'Bytes' => array( 'required' => true, 'type' => 'numeric', ), 'ImportManifestUrl' => array( 'required' => true, 'type' => 'string', ), ), ), 'Description' => array( 'type' => 'string', ), 'Volume' => array( 'type' => 'object', 'properties' => array( 'Size' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), ), ), 'Platform' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ImportKeyPair' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ImportKeyPairResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ImportKeyPair', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'KeyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PublicKeyMaterial' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'filters' => array( 'base64_encode', ), ), ), ), 'ImportVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ImportVolumeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ImportVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Image' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Format' => array( 'required' => true, 'type' => 'string', ), 'Bytes' => array( 'required' => true, 'type' => 'numeric', ), 'ImportManifestUrl' => array( 'required' => true, 'type' => 'string', ), ), ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Volume' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Size' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), ), 'ModifyImageAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyImageAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OperationType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'UserIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'UserId', 'items' => array( 'name' => 'UserId', 'type' => 'string', ), ), 'UserGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'UserGroup', 'items' => array( 'name' => 'UserGroup', 'type' => 'string', ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ProductCode', 'items' => array( 'name' => 'ProductCode', 'type' => 'string', ), ), 'Value' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LaunchPermission' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Add' => array( 'type' => 'array', 'items' => array( 'name' => 'LaunchPermission', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'Group' => array( 'type' => 'string', ), ), ), ), 'Remove' => array( 'type' => 'array', 'items' => array( 'name' => 'LaunchPermission', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'Group' => array( 'type' => 'string', ), ), ), ), ), ), 'Description' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), ), ), 'ModifyInstanceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyInstanceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Value' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'VolumeId' => array( 'type' => 'string', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'VirtualName' => array( 'type' => 'string', ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), 'SourceDestCheck' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'DisableApiTermination' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'InstanceType' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'Kernel' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'Ramdisk' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'UserData' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'InstanceInitiatedShutdownBehavior' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'Groups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'GroupId', 'items' => array( 'name' => 'GroupId', 'type' => 'string', ), ), 'EbsOptimized' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'SriovNetSupport' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), ), ), 'ModifyNetworkInterfaceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyNetworkInterfaceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'SourceDestCheck' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'Groups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'Attachment' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'ModifyReservedInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ModifyReservedInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyReservedInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ClientToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ReservedInstancesIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesId', 'items' => array( 'name' => 'ReservedInstancesId', 'type' => 'string', ), ), 'TargetConfigurations' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesConfigurationSetItemType', 'items' => array( 'name' => 'ReservedInstancesConfigurationSetItemType', 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), 'Platform' => array( 'type' => 'string', ), 'InstanceCount' => array( 'type' => 'numeric', ), 'InstanceType' => array( 'type' => 'string', ), ), ), ), ), ), 'ModifySnapshotAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifySnapshotAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OperationType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'UserIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'UserId', 'items' => array( 'name' => 'UserId', 'type' => 'string', ), ), 'GroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'UserGroup', 'items' => array( 'name' => 'UserGroup', 'type' => 'string', ), ), 'CreateVolumePermission' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Add' => array( 'type' => 'array', 'items' => array( 'name' => 'CreateVolumePermission', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'Group' => array( 'type' => 'string', ), ), ), ), 'Remove' => array( 'type' => 'array', 'items' => array( 'name' => 'CreateVolumePermission', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'Group' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'ModifyVolumeAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyVolumeAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AutoEnableIO' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'ModifyVpcAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyVpcAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EnableDnsSupport' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'EnableDnsHostnames' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'MonitorInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'MonitorInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'MonitorInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), 'PurchaseReservedInstancesOffering' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'PurchaseReservedInstancesOfferingResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PurchaseReservedInstancesOffering', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ReservedInstancesOfferingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'LimitPrice' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Amount' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), ), ), ), ), 'RebootInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebootInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), 'RegisterImage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RegisterImageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RegisterImage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageLocation' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Name' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Architecture' => array( 'type' => 'string', 'location' => 'aws.query', ), 'KernelId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'RamdiskId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'RootDeviceName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'VolumeType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), 'VirtualizationType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SriovNetSupport' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReleaseAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReleaseAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PublicIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllocationId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReplaceNetworkAclAssociation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplaceNetworkAclAssociationResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReplaceNetworkAclAssociation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AssociationId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReplaceNetworkAclEntry' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReplaceNetworkAclEntry', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'Protocol' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleAction' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Egress' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'IcmpTypeCode' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Icmp', 'properties' => array( 'Type' => array( 'type' => 'numeric', ), 'Code' => array( 'type' => 'numeric', ), ), ), 'PortRange' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'From' => array( 'type' => 'numeric', ), 'To' => array( 'type' => 'numeric', ), ), ), ), ), 'ReplaceRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReplaceRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'GatewayId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReplaceRouteTableAssociation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplaceRouteTableAssociationResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReplaceRouteTableAssociation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AssociationId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReportInstanceStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReportInstanceStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Instances' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'ReasonCodes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReasonCode', 'items' => array( 'name' => 'ReasonCode', 'type' => 'string', ), ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'RequestSpotInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RequestSpotInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RequestSpotInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SpotPrice' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Type' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ValidFrom' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'ValidUntil' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'LaunchGroup' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZoneGroup' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LaunchSpecification' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'ImageId' => array( 'type' => 'string', ), 'KeyName' => array( 'type' => 'string', ), 'UserData' => array( 'type' => 'string', ), 'AddressingType' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'Placement' => array( 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), ), ), 'KernelId' => array( 'type' => 'string', ), 'RamdiskId' => array( 'type' => 'string', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'VolumeType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), 'Monitoring' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'SubnetId' => array( 'type' => 'string', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'NetworkInterface', 'items' => array( 'name' => 'NetworkInterface', 'type' => 'object', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', ), 'DeviceIndex' => array( 'type' => 'numeric', ), 'SubnetId' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'PrivateIpAddress' => array( 'type' => 'string', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'items' => array( 'name' => 'PrivateIpAddressSpecification', 'type' => 'object', 'properties' => array( 'PrivateIpAddress' => array( 'required' => true, 'type' => 'string', ), 'Primary' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'SecurityGroupIds' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroup', 'items' => array( 'name' => 'SecurityGroup', 'type' => 'string', ), ), ), ), ), ), 'ResetImageAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetImageAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ResetInstanceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetInstanceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ResetNetworkInterfaceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetNetworkInterfaceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceDestCheck' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ResetSnapshotAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetSnapshotAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'RevokeSecurityGroupEgress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeSecurityGroupEgress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpProtocol' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FromPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ToPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CidrIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpPermissions' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'IpPermission', 'type' => 'object', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', ), 'FromPort' => array( 'type' => 'numeric', ), 'ToPort' => array( 'type' => 'numeric', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'Groups', 'items' => array( 'name' => 'Groups', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IpRange', 'type' => 'object', 'properties' => array( 'CidrIp' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'RevokeSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'GroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpProtocol' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FromPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ToPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CidrIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpPermissions' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'IpPermission', 'type' => 'object', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', ), 'FromPort' => array( 'type' => 'numeric', ), 'ToPort' => array( 'type' => 'numeric', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'Groups', 'items' => array( 'name' => 'Groups', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IpRange', 'type' => 'object', 'properties' => array( 'CidrIp' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'RunInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'reservation', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RunInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MinCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'KeyName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroup', 'items' => array( 'name' => 'SecurityGroup', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'UserData' => array( 'type' => 'string', 'location' => 'aws.query', ), 'InstanceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Placement' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'Tenancy' => array( 'type' => 'string', ), ), ), 'KernelId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'RamdiskId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'VolumeType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), 'Monitoring' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'SubnetId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DisableApiTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceInitiatedShutdownBehavior' => array( 'type' => 'string', 'location' => 'aws.query', ), 'License' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Pool' => array( 'type' => 'string', ), ), ), 'PrivateIpAddress' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClientToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AdditionalInfo' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NetworkInterfaces' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NetworkInterface', 'items' => array( 'name' => 'NetworkInterface', 'type' => 'object', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', ), 'DeviceIndex' => array( 'type' => 'numeric', ), 'SubnetId' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'PrivateIpAddress' => array( 'type' => 'string', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'PrivateIpAddressesSet', 'items' => array( 'name' => 'PrivateIpAddressesSet', 'type' => 'object', 'properties' => array( 'PrivateIpAddress' => array( 'required' => true, 'type' => 'string', ), 'Primary' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'StartInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'StartInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'StartInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'AdditionalInfo' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'StopInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'StopInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'StopInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'Force' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'TerminateInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'TerminateInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'TerminateInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), 'UnassignPrivateIpAddresses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UnassignPrivateIpAddresses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PrivateIpAddresses' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PrivateIpAddress', 'items' => array( 'name' => 'PrivateIpAddress', 'type' => 'string', ), ), ), ), 'UnmonitorInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UnmonitorInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UnmonitorInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'AllocateAddressResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'publicIp', ), 'Domain' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'domain', ), 'AllocationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'allocationId', ), ), ), 'AssociateAddressResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AssociationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'associationId', ), ), ), 'AssociateRouteTableResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AssociationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'associationId', ), ), ), 'AttachNetworkInterfaceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'attachmentId', ), ), ), 'attachment' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeId', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'instanceId', ), 'Device' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'device', ), 'State' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'location' => 'xml', 'sentAs' => 'deleteOnTermination', ), ), ), 'AttachVpnGatewayResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpcAttachment' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'attachment', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), 'BundleInstanceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'BundleTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'bundleInstanceTask', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'BundleId' => array( 'type' => 'string', 'sentAs' => 'bundleId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StartTime' => array( 'type' => 'string', 'sentAs' => 'startTime', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Storage' => array( 'type' => 'object', 'sentAs' => 'storage', 'properties' => array( 'S3' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'AWSAccessKeyId' => array( 'type' => 'string', ), 'UploadPolicy' => array( 'type' => 'string', 'sentAs' => 'uploadPolicy', ), 'UploadPolicySignature' => array( 'type' => 'string', 'sentAs' => 'uploadPolicySignature', ), ), ), ), ), 'Progress' => array( 'type' => 'string', 'sentAs' => 'progress', ), 'BundleTaskError' => array( 'type' => 'object', 'sentAs' => 'error', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), 'CancelBundleTaskResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'BundleTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'bundleInstanceTask', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'BundleId' => array( 'type' => 'string', 'sentAs' => 'bundleId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StartTime' => array( 'type' => 'string', 'sentAs' => 'startTime', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Storage' => array( 'type' => 'object', 'sentAs' => 'storage', 'properties' => array( 'S3' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'AWSAccessKeyId' => array( 'type' => 'string', ), 'UploadPolicy' => array( 'type' => 'string', 'sentAs' => 'uploadPolicy', ), 'UploadPolicySignature' => array( 'type' => 'string', 'sentAs' => 'uploadPolicySignature', ), ), ), ), ), 'Progress' => array( 'type' => 'string', 'sentAs' => 'progress', ), 'BundleTaskError' => array( 'type' => 'object', 'sentAs' => 'error', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), 'CancelReservedInstancesListingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesListings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesListingsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesListingId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesListingId', ), 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'CreateDate' => array( 'type' => 'string', 'sentAs' => 'createDate', ), 'UpdateDate' => array( 'type' => 'string', 'sentAs' => 'updateDate', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceCounts' => array( 'type' => 'array', 'sentAs' => 'instanceCounts', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), ), ), ), 'PriceSchedules' => array( 'type' => 'array', 'sentAs' => 'priceSchedules', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Term' => array( 'type' => 'numeric', 'sentAs' => 'term', ), 'Price' => array( 'type' => 'numeric', 'sentAs' => 'price', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'Active' => array( 'type' => 'boolean', 'sentAs' => 'active', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), ), ), ), ), ), 'CancelSpotInstanceRequestsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CancelledSpotInstanceRequests' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'spotInstanceRequestSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), 'ConfirmProductInstanceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OwnerId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'ownerId', ), ), ), 'CopyImageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ImageId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'imageId', ), ), ), 'CopySnapshotResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'snapshotId', ), ), ), 'CreateCustomerGatewayResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CustomerGateway' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'customerGateway', 'properties' => array( 'CustomerGatewayId' => array( 'type' => 'string', 'sentAs' => 'customerGatewayId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'IpAddress' => array( 'type' => 'string', 'sentAs' => 'ipAddress', ), 'BgpAsn' => array( 'type' => 'string', 'sentAs' => 'bgpAsn', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'CreateDhcpOptionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DhcpOptions' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'dhcpOptions', 'properties' => array( 'DhcpOptionsId' => array( 'type' => 'string', 'sentAs' => 'dhcpOptionsId', ), 'DhcpConfigurations' => array( 'type' => 'array', 'sentAs' => 'dhcpConfigurationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'valueSet', 'items' => array( 'name' => 'item', 'type' => 'string', 'sentAs' => 'item', ), ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'CreateImageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ImageId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'imageId', ), ), ), 'CreateInstanceExportTaskResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ExportTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'exportTask', 'properties' => array( 'ExportTaskId' => array( 'type' => 'string', 'sentAs' => 'exportTaskId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceExportDetails' => array( 'type' => 'object', 'sentAs' => 'instanceExport', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'TargetEnvironment' => array( 'type' => 'string', 'sentAs' => 'targetEnvironment', ), ), ), 'ExportToS3Task' => array( 'type' => 'object', 'sentAs' => 'exportToS3', 'properties' => array( 'DiskImageFormat' => array( 'type' => 'string', 'sentAs' => 'diskImageFormat', ), 'ContainerFormat' => array( 'type' => 'string', 'sentAs' => 'containerFormat', ), 'S3Bucket' => array( 'type' => 'string', 'sentAs' => 's3Bucket', ), 'S3Key' => array( 'type' => 'string', 'sentAs' => 's3Key', ), ), ), ), ), ), ), 'CreateInternetGatewayResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InternetGateway' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'internetGateway', 'properties' => array( 'InternetGatewayId' => array( 'type' => 'string', 'sentAs' => 'internetGatewayId', ), 'Attachments' => array( 'type' => 'array', 'sentAs' => 'attachmentSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'CreateKeyPairResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'KeyName' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyName', ), 'KeyFingerprint' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyFingerprint', ), 'KeyMaterial' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyMaterial', ), ), ), 'CreateNetworkAclResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkAcl' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'networkAcl', 'properties' => array( 'NetworkAclId' => array( 'type' => 'string', 'sentAs' => 'networkAclId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'IsDefault' => array( 'type' => 'boolean', 'sentAs' => 'default', ), 'Entries' => array( 'type' => 'array', 'sentAs' => 'entrySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RuleNumber' => array( 'type' => 'numeric', 'sentAs' => 'ruleNumber', ), 'Protocol' => array( 'type' => 'string', 'sentAs' => 'protocol', ), 'RuleAction' => array( 'type' => 'string', 'sentAs' => 'ruleAction', ), 'Egress' => array( 'type' => 'boolean', 'sentAs' => 'egress', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'IcmpTypeCode' => array( 'type' => 'object', 'sentAs' => 'icmpTypeCode', 'properties' => array( 'Type' => array( 'type' => 'numeric', 'sentAs' => 'type', ), 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), ), ), 'PortRange' => array( 'type' => 'object', 'sentAs' => 'portRange', 'properties' => array( 'From' => array( 'type' => 'numeric', 'sentAs' => 'from', ), 'To' => array( 'type' => 'numeric', 'sentAs' => 'to', ), ), ), ), ), ), 'Associations' => array( 'type' => 'array', 'sentAs' => 'associationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkAclAssociationId' => array( 'type' => 'string', 'sentAs' => 'networkAclAssociationId', ), 'NetworkAclId' => array( 'type' => 'string', 'sentAs' => 'networkAclId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'CreateNetworkInterfaceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkInterface' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'networkInterface', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'RequesterId' => array( 'type' => 'string', 'sentAs' => 'requesterId', ), 'RequesterManaged' => array( 'type' => 'boolean', 'sentAs' => 'requesterManaged', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'MacAddress' => array( 'type' => 'string', 'sentAs' => 'macAddress', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), ), ), 'TagSet' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), ), ), ), ), ), ), ), ), ), 'CreateReservedInstancesListingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesListings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesListingsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesListingId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesListingId', ), 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'CreateDate' => array( 'type' => 'string', 'sentAs' => 'createDate', ), 'UpdateDate' => array( 'type' => 'string', 'sentAs' => 'updateDate', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceCounts' => array( 'type' => 'array', 'sentAs' => 'instanceCounts', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), ), ), ), 'PriceSchedules' => array( 'type' => 'array', 'sentAs' => 'priceSchedules', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Term' => array( 'type' => 'numeric', 'sentAs' => 'term', ), 'Price' => array( 'type' => 'numeric', 'sentAs' => 'price', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'Active' => array( 'type' => 'boolean', 'sentAs' => 'active', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), ), ), ), ), ), 'CreateRouteTableResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RouteTable' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'routeTable', 'properties' => array( 'RouteTableId' => array( 'type' => 'string', 'sentAs' => 'routeTableId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Routes' => array( 'type' => 'array', 'sentAs' => 'routeSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DestinationCidrBlock' => array( 'type' => 'string', 'sentAs' => 'destinationCidrBlock', ), 'GatewayId' => array( 'type' => 'string', 'sentAs' => 'gatewayId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Associations' => array( 'type' => 'array', 'sentAs' => 'associationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RouteTableAssociationId' => array( 'type' => 'string', 'sentAs' => 'routeTableAssociationId', ), 'RouteTableId' => array( 'type' => 'string', 'sentAs' => 'routeTableId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'Main' => array( 'type' => 'boolean', 'sentAs' => 'main', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'PropagatingVgws' => array( 'type' => 'array', 'sentAs' => 'propagatingVgwSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GatewayId' => array( 'type' => 'string', 'sentAs' => 'gatewayId', ), ), ), ), ), ), ), ), 'CreateSecurityGroupResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GroupId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'groupId', ), ), ), 'snapshot' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'snapshotId', ), 'VolumeId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeId', ), 'State' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'status', ), 'StartTime' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'startTime', ), 'Progress' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'progress', ), 'OwnerId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'ownerId', ), 'Description' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'description', ), 'VolumeSize' => array( 'type' => 'numeric', 'location' => 'xml', 'sentAs' => 'volumeSize', ), 'OwnerAlias' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'ownerAlias', ), 'Tags' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), 'CreateSpotDatafeedSubscriptionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotDatafeedSubscription' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'spotDatafeedSubscription', 'properties' => array( 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Fault' => array( 'type' => 'object', 'sentAs' => 'fault', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), 'CreateSubnetResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subnet' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'subnet', 'properties' => array( 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'AvailableIpAddressCount' => array( 'type' => 'numeric', 'sentAs' => 'availableIpAddressCount', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'DefaultForAz' => array( 'type' => 'boolean', 'sentAs' => 'defaultForAz', ), 'MapPublicIpOnLaunch' => array( 'type' => 'boolean', 'sentAs' => 'mapPublicIpOnLaunch', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'volume' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeId', ), 'Size' => array( 'type' => 'numeric', 'location' => 'xml', 'sentAs' => 'size', ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'snapshotId', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'availabilityZone', ), 'State' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'status', ), 'CreateTime' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'createTime', ), 'Attachments' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'attachmentSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Device' => array( 'type' => 'string', 'sentAs' => 'device', ), 'State' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), 'Tags' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'VolumeType' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'xml', 'sentAs' => 'iops', ), ), ), 'CreateVpcResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Vpc' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'vpc', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'DhcpOptionsId' => array( 'type' => 'string', 'sentAs' => 'dhcpOptionsId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'InstanceTenancy' => array( 'type' => 'string', 'sentAs' => 'instanceTenancy', ), 'IsDefault' => array( 'type' => 'boolean', 'sentAs' => 'isDefault', ), ), ), ), ), 'CreateVpnConnectionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpnConnection' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'vpnConnection', 'properties' => array( 'VpnConnectionId' => array( 'type' => 'string', 'sentAs' => 'vpnConnectionId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'CustomerGatewayConfiguration' => array( 'type' => 'string', 'sentAs' => 'customerGatewayConfiguration', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'CustomerGatewayId' => array( 'type' => 'string', 'sentAs' => 'customerGatewayId', ), 'VpnGatewayId' => array( 'type' => 'string', 'sentAs' => 'vpnGatewayId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'VgwTelemetry' => array( 'type' => 'array', 'sentAs' => 'vgwTelemetry', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'OutsideIpAddress' => array( 'type' => 'string', 'sentAs' => 'outsideIpAddress', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'LastStatusChange' => array( 'type' => 'string', 'sentAs' => 'lastStatusChange', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'AcceptedRouteCount' => array( 'type' => 'numeric', 'sentAs' => 'acceptedRouteCount', ), ), ), ), 'Options' => array( 'type' => 'object', 'sentAs' => 'options', 'properties' => array( 'StaticRoutesOnly' => array( 'type' => 'boolean', 'sentAs' => 'staticRoutesOnly', ), ), ), 'Routes' => array( 'type' => 'array', 'sentAs' => 'routes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DestinationCidrBlock' => array( 'type' => 'string', 'sentAs' => 'destinationCidrBlock', ), 'Source' => array( 'type' => 'string', 'sentAs' => 'source', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), ), ), 'CreateVpnGatewayResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpnGateway' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'vpnGateway', 'properties' => array( 'VpnGatewayId' => array( 'type' => 'string', 'sentAs' => 'vpnGatewayId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'VpcAttachments' => array( 'type' => 'array', 'sentAs' => 'attachments', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'DescribeAccountAttributesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccountAttributes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'accountAttributeSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'AttributeName' => array( 'type' => 'string', 'sentAs' => 'attributeName', ), 'AttributeValues' => array( 'type' => 'array', 'sentAs' => 'attributeValueSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'AttributeValue' => array( 'type' => 'string', 'sentAs' => 'attributeValue', ), ), ), ), ), ), ), ), ), 'DescribeAddressesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Addresses' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'addressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), 'Domain' => array( 'type' => 'string', 'sentAs' => 'domain', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'NetworkInterfaceOwnerId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceOwnerId', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), ), ), ), ), ), 'DescribeAvailabilityZonesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'availabilityZoneInfo', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ZoneName' => array( 'type' => 'string', 'sentAs' => 'zoneName', ), 'State' => array( 'type' => 'string', 'sentAs' => 'zoneState', ), 'RegionName' => array( 'type' => 'string', 'sentAs' => 'regionName', ), 'Messages' => array( 'type' => 'array', 'sentAs' => 'messageSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), ), ), 'DescribeBundleTasksResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'BundleTasks' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'bundleInstanceTasksSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'BundleId' => array( 'type' => 'string', 'sentAs' => 'bundleId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StartTime' => array( 'type' => 'string', 'sentAs' => 'startTime', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Storage' => array( 'type' => 'object', 'sentAs' => 'storage', 'properties' => array( 'S3' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'AWSAccessKeyId' => array( 'type' => 'string', ), 'UploadPolicy' => array( 'type' => 'string', 'sentAs' => 'uploadPolicy', ), 'UploadPolicySignature' => array( 'type' => 'string', 'sentAs' => 'uploadPolicySignature', ), ), ), ), ), 'Progress' => array( 'type' => 'string', 'sentAs' => 'progress', ), 'BundleTaskError' => array( 'type' => 'object', 'sentAs' => 'error', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), ), 'DescribeConversionTasksResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ConversionTasks' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'conversionTasks', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ConversionTaskId' => array( 'type' => 'string', 'sentAs' => 'conversionTaskId', ), 'ExpirationTime' => array( 'type' => 'string', 'sentAs' => 'expirationTime', ), 'ImportInstance' => array( 'type' => 'object', 'sentAs' => 'importInstance', 'properties' => array( 'Volumes' => array( 'type' => 'array', 'sentAs' => 'volumes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), 'ImportVolume' => array( 'type' => 'object', 'sentAs' => 'importVolume', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), ), ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeCustomerGatewaysResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CustomerGateways' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'customerGatewaySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'CustomerGatewayId' => array( 'type' => 'string', 'sentAs' => 'customerGatewayId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'IpAddress' => array( 'type' => 'string', 'sentAs' => 'ipAddress', ), 'BgpAsn' => array( 'type' => 'string', 'sentAs' => 'bgpAsn', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeDhcpOptionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DhcpOptions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'dhcpOptionsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DhcpOptionsId' => array( 'type' => 'string', 'sentAs' => 'dhcpOptionsId', ), 'DhcpConfigurations' => array( 'type' => 'array', 'sentAs' => 'dhcpConfigurationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'valueSet', 'items' => array( 'name' => 'item', 'type' => 'string', 'sentAs' => 'item', ), ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeExportTasksResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ExportTasks' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'exportTaskSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ExportTaskId' => array( 'type' => 'string', 'sentAs' => 'exportTaskId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceExportDetails' => array( 'type' => 'object', 'sentAs' => 'instanceExport', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'TargetEnvironment' => array( 'type' => 'string', 'sentAs' => 'targetEnvironment', ), ), ), 'ExportToS3Task' => array( 'type' => 'object', 'sentAs' => 'exportToS3', 'properties' => array( 'DiskImageFormat' => array( 'type' => 'string', 'sentAs' => 'diskImageFormat', ), 'ContainerFormat' => array( 'type' => 'string', 'sentAs' => 'containerFormat', ), 'S3Bucket' => array( 'type' => 'string', 'sentAs' => 's3Bucket', ), 'S3Key' => array( 'type' => 'string', 'sentAs' => 's3Key', ), ), ), ), ), ), ), ), 'imageAttribute' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ImageId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'imageId', ), 'LaunchPermissions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'launchPermission', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'UserId' => array( 'type' => 'string', 'sentAs' => 'userId', ), 'Group' => array( 'type' => 'string', 'sentAs' => 'group', ), ), ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'KernelId' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'kernel', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'RamdiskId' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'ramdisk', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'Description' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'description', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'SriovNetSupport' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'sriovNetSupport', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'sentAs' => 'virtualName', ), 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), 'NoDevice' => array( 'type' => 'string', 'sentAs' => 'noDevice', ), ), ), ), ), ), 'DescribeImagesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Images' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'imagesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'ImageLocation' => array( 'type' => 'string', 'sentAs' => 'imageLocation', ), 'State' => array( 'type' => 'string', 'sentAs' => 'imageState', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'imageOwnerId', ), 'Public' => array( 'type' => 'boolean', 'sentAs' => 'isPublic', ), 'ProductCodes' => array( 'type' => 'array', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'Architecture' => array( 'type' => 'string', 'sentAs' => 'architecture', ), 'ImageType' => array( 'type' => 'string', 'sentAs' => 'imageType', ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'SriovNetSupport' => array( 'type' => 'string', 'sentAs' => 'sriovNetSupport', ), 'StateReason' => array( 'type' => 'object', 'sentAs' => 'stateReason', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'ImageOwnerAlias' => array( 'type' => 'string', 'sentAs' => 'imageOwnerAlias', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'RootDeviceType' => array( 'type' => 'string', 'sentAs' => 'rootDeviceType', ), 'RootDeviceName' => array( 'type' => 'string', 'sentAs' => 'rootDeviceName', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'sentAs' => 'virtualName', ), 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), 'NoDevice' => array( 'type' => 'string', 'sentAs' => 'noDevice', ), ), ), ), 'VirtualizationType' => array( 'type' => 'string', 'sentAs' => 'virtualizationType', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'Hypervisor' => array( 'type' => 'string', 'sentAs' => 'hypervisor', ), ), ), ), ), ), 'InstanceAttribute' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'instanceId', ), 'InstanceType' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'instanceType', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'KernelId' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'kernel', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'RamdiskId' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'ramdisk', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'UserData' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'userData', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'DisableApiTermination' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'disableApiTermination', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'InstanceInitiatedShutdownBehavior' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'instanceInitiatedShutdownBehavior', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'RootDeviceName' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'rootDeviceName', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'EbsOptimized' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'ebsOptimized', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'SriovNetSupport' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'sriovNetSupport', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), 'DescribeInstanceStatusResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceStatuses' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instanceStatusSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Events' => array( 'type' => 'array', 'sentAs' => 'eventsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'NotBefore' => array( 'type' => 'string', 'sentAs' => 'notBefore', ), 'NotAfter' => array( 'type' => 'string', 'sentAs' => 'notAfter', ), ), ), ), 'InstanceState' => array( 'type' => 'object', 'sentAs' => 'instanceState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'SystemStatus' => array( 'type' => 'object', 'sentAs' => 'systemStatus', 'properties' => array( 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'Details' => array( 'type' => 'array', 'sentAs' => 'details', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'ImpairedSince' => array( 'type' => 'string', 'sentAs' => 'impairedSince', ), ), ), ), ), ), 'InstanceStatus' => array( 'type' => 'object', 'sentAs' => 'instanceStatus', 'properties' => array( 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'Details' => array( 'type' => 'array', 'sentAs' => 'details', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'ImpairedSince' => array( 'type' => 'string', 'sentAs' => 'impairedSince', ), ), ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Reservations' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservationId' => array( 'type' => 'string', 'sentAs' => 'reservationId', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'RequesterId' => array( 'type' => 'string', 'sentAs' => 'requesterId', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Instances' => array( 'type' => 'array', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'State' => array( 'type' => 'object', 'sentAs' => 'instanceState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'dnsName', ), 'StateTransitionReason' => array( 'type' => 'string', 'sentAs' => 'reason', ), 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'AmiLaunchIndex' => array( 'type' => 'numeric', 'sentAs' => 'amiLaunchIndex', ), 'ProductCodes' => array( 'type' => 'array', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'LaunchTime' => array( 'type' => 'string', 'sentAs' => 'launchTime', ), 'Placement' => array( 'type' => 'object', 'sentAs' => 'placement', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'Tenancy' => array( 'type' => 'string', 'sentAs' => 'tenancy', ), ), ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Monitoring' => array( 'type' => 'object', 'sentAs' => 'monitoring', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PublicIpAddress' => array( 'type' => 'string', 'sentAs' => 'ipAddress', ), 'StateReason' => array( 'type' => 'object', 'sentAs' => 'stateReason', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'Architecture' => array( 'type' => 'string', 'sentAs' => 'architecture', ), 'RootDeviceType' => array( 'type' => 'string', 'sentAs' => 'rootDeviceType', ), 'RootDeviceName' => array( 'type' => 'string', 'sentAs' => 'rootDeviceName', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), ), ), 'VirtualizationType' => array( 'type' => 'string', 'sentAs' => 'virtualizationType', ), 'InstanceLifecycle' => array( 'type' => 'string', 'sentAs' => 'instanceLifecycle', ), 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'License' => array( 'type' => 'object', 'sentAs' => 'license', 'properties' => array( 'Pool' => array( 'type' => 'string', 'sentAs' => 'pool', ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Hypervisor' => array( 'type' => 'string', 'sentAs' => 'hypervisor', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'publicDnsName', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'publicDnsName', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), ), ), ), ), ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'sentAs' => 'iamInstanceProfile', 'properties' => array( 'Arn' => array( 'type' => 'string', 'sentAs' => 'arn', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'sentAs' => 'ebsOptimized', ), 'SriovNetSupport' => array( 'type' => 'string', 'sentAs' => 'sriovNetSupport', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeInternetGatewaysResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InternetGateways' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'internetGatewaySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InternetGatewayId' => array( 'type' => 'string', 'sentAs' => 'internetGatewayId', ), 'Attachments' => array( 'type' => 'array', 'sentAs' => 'attachmentSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeKeyPairsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'KeyPairs' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'keySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'KeyFingerprint' => array( 'type' => 'string', 'sentAs' => 'keyFingerprint', ), ), ), ), ), ), 'DescribeLicensesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Licenses' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'licenseSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'LicenseId' => array( 'type' => 'string', 'sentAs' => 'licenseId', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'Pool' => array( 'type' => 'string', 'sentAs' => 'pool', ), 'Capacities' => array( 'type' => 'array', 'sentAs' => 'capacitySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Capacity' => array( 'type' => 'numeric', 'sentAs' => 'capacity', ), 'InstanceCapacity' => array( 'type' => 'numeric', 'sentAs' => 'instanceCapacity', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'EarliestAllowedDeactivationTime' => array( 'type' => 'string', 'sentAs' => 'earliestAllowedDeactivationTime', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeNetworkAclsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkAcls' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'networkAclSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkAclId' => array( 'type' => 'string', 'sentAs' => 'networkAclId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'IsDefault' => array( 'type' => 'boolean', 'sentAs' => 'default', ), 'Entries' => array( 'type' => 'array', 'sentAs' => 'entrySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RuleNumber' => array( 'type' => 'numeric', 'sentAs' => 'ruleNumber', ), 'Protocol' => array( 'type' => 'string', 'sentAs' => 'protocol', ), 'RuleAction' => array( 'type' => 'string', 'sentAs' => 'ruleAction', ), 'Egress' => array( 'type' => 'boolean', 'sentAs' => 'egress', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'IcmpTypeCode' => array( 'type' => 'object', 'sentAs' => 'icmpTypeCode', 'properties' => array( 'Type' => array( 'type' => 'numeric', 'sentAs' => 'type', ), 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), ), ), 'PortRange' => array( 'type' => 'object', 'sentAs' => 'portRange', 'properties' => array( 'From' => array( 'type' => 'numeric', 'sentAs' => 'from', ), 'To' => array( 'type' => 'numeric', 'sentAs' => 'to', ), ), ), ), ), ), 'Associations' => array( 'type' => 'array', 'sentAs' => 'associationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkAclAssociationId' => array( 'type' => 'string', 'sentAs' => 'networkAclAssociationId', ), 'NetworkAclId' => array( 'type' => 'string', 'sentAs' => 'networkAclId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeNetworkInterfaceAttributeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'networkInterfaceId', ), 'Description' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'description', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'SourceDestCheck' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'sourceDestCheck', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'Groups' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), ), 'DescribeNetworkInterfacesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkInterfaces' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'RequesterId' => array( 'type' => 'string', 'sentAs' => 'requesterId', ), 'RequesterManaged' => array( 'type' => 'boolean', 'sentAs' => 'requesterManaged', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'MacAddress' => array( 'type' => 'string', 'sentAs' => 'macAddress', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), ), ), 'TagSet' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), ), ), ), ), ), ), ), ), ), ), 'DescribePlacementGroupsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PlacementGroups' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'placementGroupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'Strategy' => array( 'type' => 'string', 'sentAs' => 'strategy', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), 'DescribeRegionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Regions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'regionInfo', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RegionName' => array( 'type' => 'string', 'sentAs' => 'regionName', ), 'Endpoint' => array( 'type' => 'string', 'sentAs' => 'regionEndpoint', ), ), ), ), ), ), 'DescribeReservedInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Start' => array( 'type' => 'string', 'sentAs' => 'start', ), 'End' => array( 'type' => 'string', 'sentAs' => 'end', ), 'Duration' => array( 'type' => 'numeric', 'sentAs' => 'duration', ), 'UsagePrice' => array( 'type' => 'numeric', 'sentAs' => 'usagePrice', ), 'FixedPrice' => array( 'type' => 'numeric', 'sentAs' => 'fixedPrice', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'InstanceTenancy' => array( 'type' => 'string', 'sentAs' => 'instanceTenancy', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'OfferingType' => array( 'type' => 'string', 'sentAs' => 'offeringType', ), 'RecurringCharges' => array( 'type' => 'array', 'sentAs' => 'recurringCharges', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Frequency' => array( 'type' => 'string', 'sentAs' => 'frequency', ), 'Amount' => array( 'type' => 'numeric', 'sentAs' => 'amount', ), ), ), ), ), ), ), ), ), 'DescribeReservedInstancesListingsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesListings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesListingsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesListingId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesListingId', ), 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'CreateDate' => array( 'type' => 'string', 'sentAs' => 'createDate', ), 'UpdateDate' => array( 'type' => 'string', 'sentAs' => 'updateDate', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceCounts' => array( 'type' => 'array', 'sentAs' => 'instanceCounts', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), ), ), ), 'PriceSchedules' => array( 'type' => 'array', 'sentAs' => 'priceSchedules', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Term' => array( 'type' => 'numeric', 'sentAs' => 'term', ), 'Price' => array( 'type' => 'numeric', 'sentAs' => 'price', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'Active' => array( 'type' => 'boolean', 'sentAs' => 'active', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), ), ), ), ), ), 'DescribeReservedInstancesModificationsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesModifications' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesModificationsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesModificationId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesModificationId', ), 'ReservedInstancesIds' => array( 'type' => 'array', 'sentAs' => 'reservedInstancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), ), ), ), 'ModificationResults' => array( 'type' => 'array', 'sentAs' => 'modificationResultSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'TargetConfiguration' => array( 'type' => 'object', 'sentAs' => 'targetConfiguration', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), ), ), ), ), ), 'CreateDate' => array( 'type' => 'string', 'sentAs' => 'createDate', ), 'UpdateDate' => array( 'type' => 'string', 'sentAs' => 'updateDate', ), 'EffectiveDate' => array( 'type' => 'string', 'sentAs' => 'effectiveDate', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeReservedInstancesOfferingsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesOfferings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesOfferingsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesOfferingId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesOfferingId', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Duration' => array( 'type' => 'numeric', 'sentAs' => 'duration', ), 'UsagePrice' => array( 'type' => 'numeric', 'sentAs' => 'usagePrice', ), 'FixedPrice' => array( 'type' => 'numeric', 'sentAs' => 'fixedPrice', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'InstanceTenancy' => array( 'type' => 'string', 'sentAs' => 'instanceTenancy', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'OfferingType' => array( 'type' => 'string', 'sentAs' => 'offeringType', ), 'RecurringCharges' => array( 'type' => 'array', 'sentAs' => 'recurringCharges', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Frequency' => array( 'type' => 'string', 'sentAs' => 'frequency', ), 'Amount' => array( 'type' => 'numeric', 'sentAs' => 'amount', ), ), ), ), 'Marketplace' => array( 'type' => 'boolean', 'sentAs' => 'marketplace', ), 'PricingDetails' => array( 'type' => 'array', 'sentAs' => 'pricingDetailsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Price' => array( 'type' => 'numeric', 'sentAs' => 'price', ), 'Count' => array( 'type' => 'numeric', 'sentAs' => 'count', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeRouteTablesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RouteTables' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'routeTableSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RouteTableId' => array( 'type' => 'string', 'sentAs' => 'routeTableId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Routes' => array( 'type' => 'array', 'sentAs' => 'routeSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DestinationCidrBlock' => array( 'type' => 'string', 'sentAs' => 'destinationCidrBlock', ), 'GatewayId' => array( 'type' => 'string', 'sentAs' => 'gatewayId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Associations' => array( 'type' => 'array', 'sentAs' => 'associationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RouteTableAssociationId' => array( 'type' => 'string', 'sentAs' => 'routeTableAssociationId', ), 'RouteTableId' => array( 'type' => 'string', 'sentAs' => 'routeTableId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'Main' => array( 'type' => 'boolean', 'sentAs' => 'main', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'PropagatingVgws' => array( 'type' => 'array', 'sentAs' => 'propagatingVgwSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GatewayId' => array( 'type' => 'string', 'sentAs' => 'gatewayId', ), ), ), ), ), ), ), ), ), 'DescribeSecurityGroupsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'securityGroupInfo', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'groupDescription', ), 'IpPermissions' => array( 'type' => 'array', 'sentAs' => 'ipPermissions', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', 'sentAs' => 'ipProtocol', ), 'FromPort' => array( 'type' => 'numeric', 'sentAs' => 'fromPort', ), 'ToPort' => array( 'type' => 'numeric', 'sentAs' => 'toPort', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'groups', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'UserId' => array( 'type' => 'string', 'sentAs' => 'userId', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'sentAs' => 'ipRanges', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'CidrIp' => array( 'type' => 'string', 'sentAs' => 'cidrIp', ), ), ), ), ), ), ), 'IpPermissionsEgress' => array( 'type' => 'array', 'sentAs' => 'ipPermissionsEgress', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', 'sentAs' => 'ipProtocol', ), 'FromPort' => array( 'type' => 'numeric', 'sentAs' => 'fromPort', ), 'ToPort' => array( 'type' => 'numeric', 'sentAs' => 'toPort', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'groups', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'UserId' => array( 'type' => 'string', 'sentAs' => 'userId', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'sentAs' => 'ipRanges', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'CidrIp' => array( 'type' => 'string', 'sentAs' => 'cidrIp', ), ), ), ), ), ), ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeSnapshotAttributeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'snapshotId', ), 'CreateVolumePermissions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'createVolumePermission', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'UserId' => array( 'type' => 'string', 'sentAs' => 'userId', ), 'Group' => array( 'type' => 'string', 'sentAs' => 'group', ), ), ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), ), ), 'DescribeSnapshotsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Snapshots' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'snapshotSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StartTime' => array( 'type' => 'string', 'sentAs' => 'startTime', ), 'Progress' => array( 'type' => 'string', 'sentAs' => 'progress', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'OwnerAlias' => array( 'type' => 'string', 'sentAs' => 'ownerAlias', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeSpotDatafeedSubscriptionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotDatafeedSubscription' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'spotDatafeedSubscription', 'properties' => array( 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Fault' => array( 'type' => 'object', 'sentAs' => 'fault', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), 'DescribeSpotInstanceRequestsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotInstanceRequests' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'spotInstanceRequestSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'SpotPrice' => array( 'type' => 'string', 'sentAs' => 'spotPrice', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Fault' => array( 'type' => 'object', 'sentAs' => 'fault', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'Status' => array( 'type' => 'object', 'sentAs' => 'status', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'ValidFrom' => array( 'type' => 'string', 'sentAs' => 'validFrom', ), 'ValidUntil' => array( 'type' => 'string', 'sentAs' => 'validUntil', ), 'LaunchGroup' => array( 'type' => 'string', 'sentAs' => 'launchGroup', ), 'AvailabilityZoneGroup' => array( 'type' => 'string', 'sentAs' => 'availabilityZoneGroup', ), 'LaunchSpecification' => array( 'type' => 'object', 'sentAs' => 'launchSpecification', 'properties' => array( 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'UserData' => array( 'type' => 'string', 'sentAs' => 'userData', ), 'AddressingType' => array( 'type' => 'string', 'sentAs' => 'addressingType', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'Placement' => array( 'type' => 'object', 'sentAs' => 'placement', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), ), ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'sentAs' => 'virtualName', ), 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), 'NoDevice' => array( 'type' => 'string', 'sentAs' => 'noDevice', ), ), ), ), 'MonitoringEnabled' => array( 'type' => 'boolean', 'sentAs' => 'monitoringEnabled', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', 'sentAs' => 'SecurityGroupId', ), ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', 'sentAs' => 'secondaryPrivateIpAddressCount', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'sentAs' => 'associatePublicIpAddress', ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'sentAs' => 'iamInstanceProfile', 'properties' => array( 'Arn' => array( 'type' => 'string', 'sentAs' => 'arn', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'sentAs' => 'ebsOptimized', ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CreateTime' => array( 'type' => 'string', 'sentAs' => 'createTime', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'LaunchedAvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'launchedAvailabilityZone', ), ), ), ), ), ), 'DescribeSpotPriceHistoryResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotPriceHistory' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'spotPriceHistorySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'SpotPrice' => array( 'type' => 'string', 'sentAs' => 'spotPrice', ), 'Timestamp' => array( 'type' => 'string', 'sentAs' => 'timestamp', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeSubnetsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subnets' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'subnetSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'AvailableIpAddressCount' => array( 'type' => 'numeric', 'sentAs' => 'availableIpAddressCount', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'DefaultForAz' => array( 'type' => 'boolean', 'sentAs' => 'defaultForAz', ), 'MapPublicIpOnLaunch' => array( 'type' => 'boolean', 'sentAs' => 'mapPublicIpOnLaunch', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeTagsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Tags' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ResourceId' => array( 'type' => 'string', 'sentAs' => 'resourceId', ), 'ResourceType' => array( 'type' => 'string', 'sentAs' => 'resourceType', ), 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeVolumeAttributeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeId', ), 'AutoEnableIO' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'autoEnableIO', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), ), ), 'DescribeVolumeStatusResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeStatuses' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'volumeStatusSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'VolumeStatus' => array( 'type' => 'object', 'sentAs' => 'volumeStatus', 'properties' => array( 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'Details' => array( 'type' => 'array', 'sentAs' => 'details', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), ), ), ), ), ), 'Events' => array( 'type' => 'array', 'sentAs' => 'eventsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'EventType' => array( 'type' => 'string', 'sentAs' => 'eventType', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'NotBefore' => array( 'type' => 'string', 'sentAs' => 'notBefore', ), 'NotAfter' => array( 'type' => 'string', 'sentAs' => 'notAfter', ), 'EventId' => array( 'type' => 'string', 'sentAs' => 'eventId', ), ), ), ), 'Actions' => array( 'type' => 'array', 'sentAs' => 'actionsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'EventType' => array( 'type' => 'string', 'sentAs' => 'eventType', ), 'EventId' => array( 'type' => 'string', 'sentAs' => 'eventId', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeVolumesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Volumes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'volumeSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'State' => array( 'type' => 'string', 'sentAs' => 'status', ), 'CreateTime' => array( 'type' => 'string', 'sentAs' => 'createTime', ), 'Attachments' => array( 'type' => 'array', 'sentAs' => 'attachmentSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Device' => array( 'type' => 'string', 'sentAs' => 'device', ), 'State' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), ), ), ), 'DescribeVpcAttributeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpcId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'vpcId', ), 'EnableDnsSupport' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'enableDnsSupport', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'EnableDnsHostnames' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'enableDnsHostnames', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), ), ), 'DescribeVpcsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Vpcs' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'vpcSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'DhcpOptionsId' => array( 'type' => 'string', 'sentAs' => 'dhcpOptionsId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'InstanceTenancy' => array( 'type' => 'string', 'sentAs' => 'instanceTenancy', ), 'IsDefault' => array( 'type' => 'boolean', 'sentAs' => 'isDefault', ), ), ), ), ), ), 'DescribeVpnConnectionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpnConnections' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'vpnConnectionSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpnConnectionId' => array( 'type' => 'string', 'sentAs' => 'vpnConnectionId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'CustomerGatewayConfiguration' => array( 'type' => 'string', 'sentAs' => 'customerGatewayConfiguration', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'CustomerGatewayId' => array( 'type' => 'string', 'sentAs' => 'customerGatewayId', ), 'VpnGatewayId' => array( 'type' => 'string', 'sentAs' => 'vpnGatewayId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'VgwTelemetry' => array( 'type' => 'array', 'sentAs' => 'vgwTelemetry', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'OutsideIpAddress' => array( 'type' => 'string', 'sentAs' => 'outsideIpAddress', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'LastStatusChange' => array( 'type' => 'string', 'sentAs' => 'lastStatusChange', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'AcceptedRouteCount' => array( 'type' => 'numeric', 'sentAs' => 'acceptedRouteCount', ), ), ), ), 'Options' => array( 'type' => 'object', 'sentAs' => 'options', 'properties' => array( 'StaticRoutesOnly' => array( 'type' => 'boolean', 'sentAs' => 'staticRoutesOnly', ), ), ), 'Routes' => array( 'type' => 'array', 'sentAs' => 'routes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DestinationCidrBlock' => array( 'type' => 'string', 'sentAs' => 'destinationCidrBlock', ), 'Source' => array( 'type' => 'string', 'sentAs' => 'source', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), ), ), ), 'DescribeVpnGatewaysResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpnGateways' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'vpnGatewaySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpnGatewayId' => array( 'type' => 'string', 'sentAs' => 'vpnGatewayId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'VpcAttachments' => array( 'type' => 'array', 'sentAs' => 'attachments', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'GetConsoleOutputResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'instanceId', ), 'Timestamp' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'timestamp', ), 'Output' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'output', ), ), ), 'GetPasswordDataResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'instanceId', ), 'Timestamp' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'timestamp', ), 'PasswordData' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'passwordData', ), ), ), 'ImportInstanceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ConversionTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'conversionTask', 'properties' => array( 'ConversionTaskId' => array( 'type' => 'string', 'sentAs' => 'conversionTaskId', ), 'ExpirationTime' => array( 'type' => 'string', 'sentAs' => 'expirationTime', ), 'ImportInstance' => array( 'type' => 'object', 'sentAs' => 'importInstance', 'properties' => array( 'Volumes' => array( 'type' => 'array', 'sentAs' => 'volumes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), 'ImportVolume' => array( 'type' => 'object', 'sentAs' => 'importVolume', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), ), ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'ImportKeyPairResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'KeyName' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyName', ), 'KeyFingerprint' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyFingerprint', ), ), ), 'ImportVolumeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ConversionTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'conversionTask', 'properties' => array( 'ConversionTaskId' => array( 'type' => 'string', 'sentAs' => 'conversionTaskId', ), 'ExpirationTime' => array( 'type' => 'string', 'sentAs' => 'expirationTime', ), 'ImportInstance' => array( 'type' => 'object', 'sentAs' => 'importInstance', 'properties' => array( 'Volumes' => array( 'type' => 'array', 'sentAs' => 'volumes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), 'ImportVolume' => array( 'type' => 'object', 'sentAs' => 'importVolume', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), ), ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'ModifyReservedInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesModificationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'reservedInstancesModificationId', ), ), ), 'MonitorInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceMonitorings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Monitoring' => array( 'type' => 'object', 'sentAs' => 'monitoring', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), ), ), 'PurchaseReservedInstancesOfferingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'reservedInstancesId', ), ), ), 'RegisterImageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ImageId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'imageId', ), ), ), 'ReplaceNetworkAclAssociationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NewAssociationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'newAssociationId', ), ), ), 'ReplaceRouteTableAssociationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NewAssociationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'newAssociationId', ), ), ), 'RequestSpotInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotInstanceRequests' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'spotInstanceRequestSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'SpotPrice' => array( 'type' => 'string', 'sentAs' => 'spotPrice', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Fault' => array( 'type' => 'object', 'sentAs' => 'fault', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'Status' => array( 'type' => 'object', 'sentAs' => 'status', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'ValidFrom' => array( 'type' => 'string', 'sentAs' => 'validFrom', ), 'ValidUntil' => array( 'type' => 'string', 'sentAs' => 'validUntil', ), 'LaunchGroup' => array( 'type' => 'string', 'sentAs' => 'launchGroup', ), 'AvailabilityZoneGroup' => array( 'type' => 'string', 'sentAs' => 'availabilityZoneGroup', ), 'LaunchSpecification' => array( 'type' => 'object', 'sentAs' => 'launchSpecification', 'properties' => array( 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'UserData' => array( 'type' => 'string', 'sentAs' => 'userData', ), 'AddressingType' => array( 'type' => 'string', 'sentAs' => 'addressingType', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'Placement' => array( 'type' => 'object', 'sentAs' => 'placement', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), ), ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'sentAs' => 'virtualName', ), 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), 'NoDevice' => array( 'type' => 'string', 'sentAs' => 'noDevice', ), ), ), ), 'MonitoringEnabled' => array( 'type' => 'boolean', 'sentAs' => 'monitoringEnabled', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', 'sentAs' => 'SecurityGroupId', ), ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', 'sentAs' => 'secondaryPrivateIpAddressCount', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'sentAs' => 'associatePublicIpAddress', ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'sentAs' => 'iamInstanceProfile', 'properties' => array( 'Arn' => array( 'type' => 'string', 'sentAs' => 'arn', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'sentAs' => 'ebsOptimized', ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CreateTime' => array( 'type' => 'string', 'sentAs' => 'createTime', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'LaunchedAvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'launchedAvailabilityZone', ), ), ), ), ), ), 'reservation' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'reservationId', ), 'OwnerId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'ownerId', ), 'RequesterId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'requesterId', ), 'Groups' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Instances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'State' => array( 'type' => 'object', 'sentAs' => 'instanceState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'dnsName', ), 'StateTransitionReason' => array( 'type' => 'string', 'sentAs' => 'reason', ), 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'AmiLaunchIndex' => array( 'type' => 'numeric', 'sentAs' => 'amiLaunchIndex', ), 'ProductCodes' => array( 'type' => 'array', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'LaunchTime' => array( 'type' => 'string', 'sentAs' => 'launchTime', ), 'Placement' => array( 'type' => 'object', 'sentAs' => 'placement', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'Tenancy' => array( 'type' => 'string', 'sentAs' => 'tenancy', ), ), ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Monitoring' => array( 'type' => 'object', 'sentAs' => 'monitoring', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PublicIpAddress' => array( 'type' => 'string', 'sentAs' => 'ipAddress', ), 'StateReason' => array( 'type' => 'object', 'sentAs' => 'stateReason', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'Architecture' => array( 'type' => 'string', 'sentAs' => 'architecture', ), 'RootDeviceType' => array( 'type' => 'string', 'sentAs' => 'rootDeviceType', ), 'RootDeviceName' => array( 'type' => 'string', 'sentAs' => 'rootDeviceName', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), ), ), 'VirtualizationType' => array( 'type' => 'string', 'sentAs' => 'virtualizationType', ), 'InstanceLifecycle' => array( 'type' => 'string', 'sentAs' => 'instanceLifecycle', ), 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'License' => array( 'type' => 'object', 'sentAs' => 'license', 'properties' => array( 'Pool' => array( 'type' => 'string', 'sentAs' => 'pool', ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Hypervisor' => array( 'type' => 'string', 'sentAs' => 'hypervisor', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'publicDnsName', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'publicDnsName', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), ), ), ), ), ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'sentAs' => 'iamInstanceProfile', 'properties' => array( 'Arn' => array( 'type' => 'string', 'sentAs' => 'arn', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'sentAs' => 'ebsOptimized', ), 'SriovNetSupport' => array( 'type' => 'string', 'sentAs' => 'sriovNetSupport', ), ), ), ), ), ), 'StartInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StartingInstances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CurrentState' => array( 'type' => 'object', 'sentAs' => 'currentState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PreviousState' => array( 'type' => 'object', 'sentAs' => 'previousState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), ), ), ), ), ), 'StopInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StoppingInstances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CurrentState' => array( 'type' => 'object', 'sentAs' => 'currentState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PreviousState' => array( 'type' => 'object', 'sentAs' => 'previousState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), ), ), ), ), ), 'TerminateInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TerminatingInstances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CurrentState' => array( 'type' => 'object', 'sentAs' => 'currentState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PreviousState' => array( 'type' => 'object', 'sentAs' => 'previousState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), ), ), ), ), ), 'UnmonitorInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceMonitorings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Monitoring' => array( 'type' => 'object', 'sentAs' => 'monitoring', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeAccountAttributes' => array( 'result_key' => 'AccountAttributes', ), 'DescribeAddresses' => array( 'result_key' => 'Addresses', ), 'DescribeAvailabilityZones' => array( 'result_key' => 'AvailabilityZones', ), 'DescribeBundleTasks' => array( 'result_key' => 'BundleTasks', ), 'DescribeConversionTasks' => array( 'result_key' => 'ConversionTasks', ), 'DescribeCustomerGateways' => array( 'result_key' => 'CustomerGateways', ), 'DescribeDhcpOptions' => array( 'result_key' => 'DhcpOptions', ), 'DescribeExportTasks' => array( 'result_key' => 'ExportTasks', ), 'DescribeImages' => array( 'result_key' => 'Images', ), 'DescribeInstanceStatus' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'InstanceStatuses', ), 'DescribeInstances' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'Reservations', ), 'DescribeInternetGateways' => array( 'result_key' => 'InternetGateways', ), 'DescribeKeyPairs' => array( 'result_key' => 'KeyPairs', ), 'DescribeLicenses' => array( 'result_key' => 'Licenses', ), 'DescribeNetworkAcls' => array( 'result_key' => 'NetworkAcls', ), 'DescribeNetworkInterfaces' => array( 'result_key' => 'NetworkInterfaces', ), 'DescribePlacementGroups' => array( 'result_key' => 'PlacementGroups', ), 'DescribeRegions' => array( 'result_key' => 'Regions', ), 'DescribeReservedInstances' => array( 'result_key' => 'ReservedInstances', ), 'DescribeReservedInstancesListings' => array( 'result_key' => 'ReservedInstancesListings', ), 'DescribeReservedInstancesModifications' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'ReservedInstancesModifications', ), 'DescribeReservedInstancesOfferings' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'ReservedInstancesOfferings', ), 'DescribeRouteTables' => array( 'result_key' => 'RouteTables', ), 'DescribeSecurityGroups' => array( 'result_key' => 'SecurityGroups', ), 'DescribeSnapshots' => array( 'result_key' => 'Snapshots', ), 'DescribeSpotInstanceRequests' => array( 'result_key' => 'SpotInstanceRequests', ), 'DescribeSpotPriceHistory' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'SpotPriceHistory', ), 'DescribeSubnets' => array( 'result_key' => 'Subnets', ), 'DescribeTags' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'Tags', ), 'DescribeVolumeStatus' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'VolumeStatuses', ), 'DescribeVolumes' => array( 'result_key' => 'Volumes', ), 'DescribeVpcs' => array( 'result_key' => 'Vpcs', ), 'DescribeVpnConnections' => array( 'result_key' => 'VpnConnections', ), 'DescribeVpnGateways' => array( 'result_key' => 'VpnGateways', ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 15, 'max_attempts' => 40, 'acceptor.type' => 'output', ), '__InstanceState' => array( 'operation' => 'DescribeInstances', 'acceptor.path' => 'Reservations/*/Instances/*/State/Name', ), 'InstanceRunning' => array( 'extends' => '__InstanceState', 'success.value' => 'running', 'failure.value' => array( 'shutting-down', 'terminated', 'stopping', ), ), 'InstanceStopped' => array( 'extends' => '__InstanceState', 'success.value' => 'stopped', 'failure.value' => array( 'pending', 'terminated', ), ), 'InstanceTerminated' => array( 'extends' => '__InstanceState', 'success.value' => 'terminated', 'failure.value' => array( 'pending', 'stopping', ), ), '__ExportTaskState' => array( 'operation' => 'DescribeExportTasks', 'acceptor.path' => 'ExportTasks/*/State', ), 'ExportTaskCompleted' => array( 'extends' => '__ExportTaskState', 'success.value' => 'completed', ), 'ExportTaskCancelled' => array( 'extends' => '__ExportTaskState', 'success.value' => 'cancelled', ), 'SnapshotCompleted' => array( 'operation' => 'DescribeSnapshots', 'success.path' => 'Snapshots/*/State', 'success.value' => 'completed', ), 'SubnetAvailable' => array( 'operation' => 'DescribeSubnets', 'success.path' => 'Subnets/*/State', 'success.value' => 'available', ), '__VolumeStatus' => array( 'operation' => 'DescribeVolumes', 'acceptor.key' => 'VolumeStatuses/*/VolumeStatus/Status', ), 'VolumeAvailable' => array( 'extends' => '__VolumeStatus', 'success.value' => 'available', 'failure.value' => array( 'deleted', ), ), 'VolumeInUse' => array( 'extends' => '__VolumeStatus', 'success.value' => 'in-use', 'failure.value' => array( 'deleted', ), ), 'VolumeDeleted' => array( 'extends' => '__VolumeStatus', 'success.value' => 'deleted', ), 'VpcAvailable' => array( 'operation' => 'DescribeVpcs', 'success.path' => 'Vpcs/*/State', 'success.value' => 'available', ), '__VpnConnectionState' => array( 'operation' => 'DescribeVpnConnections', 'acceptor.path' => 'VpnConnections/*/State', ), 'VpnConnectionAvailable' => array( 'extends' => '__VpnConnectionState', 'success.value' => 'available', 'failure.value' => array( 'deleting', 'deleted', ), ), 'VpnConnectionDeleted' => array( 'extends' => '__VpnConnectionState', 'success.value' => 'deleted', 'failure.value' => array( 'pending', ), ), 'BundleTaskComplete' => array( 'operation' => 'DescribeBundleTasks', 'acceptor.path' => 'BundleTasks/*/State', 'success.value' => 'complete', 'failure.value' => array( 'failed', ), ), '__ConversionTaskState' => array( 'operation' => 'DescribeConversionTasks', 'acceptor.path' => 'ConversionTasks/*/State', ), 'ConversionTaskCompleted' => array( 'extends' => '__ConversionTaskState', 'success.value' => 'completed', 'failure.value' => array( 'cancelled', 'cancelling', ), ), 'ConversionTaskCancelled' => array( 'extends' => '__ConversionTaskState', 'success.value' => 'cancelled', ), '__CustomerGatewayState' => array( 'operation' => 'DescribeCustomerGateways', 'acceptor.path' => 'CustomerGateways/*/State', ), 'CustomerGatewayAvailable' => array( 'extends' => '__CustomerGatewayState', 'success.value' => 'available', 'failure.value' => array( 'deleted', 'deleting', ), ), 'ConversionTaskDeleted' => array( 'extends' => '__CustomerGatewayState', 'success.value' => 'deleted', ), ), ); sdk-2.5.2/Aws/ElastiCache/ElastiCacheClient.php000064411532700161006750000001617512272324172016334 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elasticache-%s.php' )) ->build(); } } sdk-2.5.2/Aws/ElastiCache/Enum/SourceType.php000064411532700161006750000000165612272324172016034 0ustar '2013-06-15', 'endpointPrefix' => 'elasticache', 'serviceFullName' => 'Amazon ElastiCache', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'ElastiCache', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.ap-southeast-2.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.cn-north-1.amazonaws.com.cn', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'AuthorizeCacheSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeCacheSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The specified Amazon EC2 security group is already authorized for the specified cache security group.', 'class' => 'AuthorizationAlreadyExistsException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'CreateCacheCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCacheCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReplicationGroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NumCacheNodes' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'CacheNodeType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Engine' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheSecurityGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheSecurityGroupNames.member', 'items' => array( 'name' => 'CacheSecurityGroupName', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupIds.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'SnapshotArns' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SnapshotArns.member', 'items' => array( 'name' => 'SnapshotArn', 'type' => 'string', ), ), 'PreferredAvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'NotificationTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified replication group does not exist.', 'class' => 'ReplicationGroupNotFoundException', ), array( 'reason' => 'The requested replication group is not in the available state.', 'class' => 'InvalidReplicationGroupStateException', ), array( 'reason' => 'This user already has a cache cluster with the given identifier.', 'class' => 'CacheClusterAlreadyExistsException', ), array( 'reason' => 'The requested cache node type is not available in the specified Availability Zone.', 'class' => 'InsufficientCacheClusterCapacityException', ), array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The requested cache subnet group name does not refer to an existing cache subnet group.', 'class' => 'CacheSubnetGroupNotFoundException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache clusters per customer.', 'class' => 'ClusterQuotaForCustomerExceededException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes in a single cache cluster.', 'class' => 'NodeQuotaForClusterExceededException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes per customer.', 'class' => 'NodeQuotaForCustomerExceededException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The VPC network is in an invalid state.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'CreateCacheParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCacheParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request cannot be processed because it would exceed the maximum number of cache security groups.', 'class' => 'CacheParameterGroupQuotaExceededException', ), array( 'reason' => 'A cache parameter group with the requested name already exists.', 'class' => 'CacheParameterGroupAlreadyExistsException', ), array( 'reason' => 'The current state of the cache parameter group does not allow the requested action to occur.', 'class' => 'InvalidCacheParameterGroupStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'CreateCacheSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCacheSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'A cache security group with the specified name already exists.', 'class' => 'CacheSecurityGroupAlreadyExistsException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache security groups.', 'class' => 'CacheSecurityGroupQuotaExceededException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'CreateCacheSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCacheSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CacheSubnetGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache subnet group name is already in use by an existing cache subnet group.', 'class' => 'CacheSubnetGroupAlreadyExistsException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache subnet groups.', 'class' => 'CacheSubnetGroupQuotaExceededException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of subnets in a cache subnet group.', 'class' => 'CacheSubnetQuotaExceededException', ), array( 'reason' => 'An invalid subnet identifier was specified.', 'class' => 'InvalidSubnetException', ), ), ), 'CreateReplicationGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplicationGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateReplicationGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReplicationGroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PrimaryClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReplicationGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The specified replication group already exists.', 'class' => 'ReplicationGroupAlreadyExistsException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DeleteCacheCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCacheCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DeleteCacheParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCacheParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The current state of the cache parameter group does not allow the requested action to occur.', 'class' => 'InvalidCacheParameterGroupStateException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DeleteCacheSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCacheSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DeleteCacheSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCacheSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache subnet group is currently in use.', 'class' => 'CacheSubnetGroupInUseException', ), array( 'reason' => 'The requested cache subnet group name does not refer to an existing cache subnet group.', 'class' => 'CacheSubnetGroupNotFoundException', ), ), ), 'DeleteReplicationGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplicationGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteReplicationGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReplicationGroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified replication group does not exist.', 'class' => 'ReplicationGroupNotFoundException', ), array( 'reason' => 'The requested replication group is not in the available state.', 'class' => 'InvalidReplicationGroupStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheClusters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheClusters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ShowCacheNodeInfo' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheEngineVersions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheEngineVersionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheEngineVersions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'Engine' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupFamily' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DefaultOnly' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DescribeCacheParameterGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheParameterGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupDetails', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Source' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheSecurityGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSecurityGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheSecurityGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheSubnetGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSubnetGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheSubnetGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache subnet group name does not refer to an existing cache subnet group.', 'class' => 'CacheSubnetGroupNotFoundException', ), ), ), 'DescribeEngineDefaultParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EngineDefaultsWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEngineDefaultParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'SourceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeReplicationGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplicationGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReplicationGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReplicationGroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified replication group does not exist.', 'class' => 'ReplicationGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeReservedCacheNodes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedCacheNodeMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedCacheNodes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReservedCacheNodeId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheNodeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested reserved cache node was not found.', 'class' => 'ReservedCacheNodeNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeReservedCacheNodesOfferings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedCacheNodesOfferingMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedCacheNodesOfferings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheNodeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache node offering does not exist.', 'class' => 'ReservedCacheNodesOfferingNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'ModifyCacheCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyCacheCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NumCacheNodes' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CacheNodeIdsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheNodeIdsToRemove.member', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', ), ), 'CacheSecurityGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheSecurityGroupNames.member', 'items' => array( 'name' => 'CacheSecurityGroupName', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupIds.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NotificationTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NotificationTopicStatus' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ApplyImmediately' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes in a single cache cluster.', 'class' => 'NodeQuotaForClusterExceededException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes per customer.', 'class' => 'NodeQuotaForCustomerExceededException', ), array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The VPC network is in an invalid state.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'ModifyCacheParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyCacheParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ParameterNameValues' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ParameterNameValues.member', 'items' => array( 'name' => 'ParameterNameValue', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The current state of the cache parameter group does not allow the requested action to occur.', 'class' => 'InvalidCacheParameterGroupStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'ModifyCacheSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyCacheSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CacheSubnetGroupDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache subnet group name does not refer to an existing cache subnet group.', 'class' => 'CacheSubnetGroupNotFoundException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of subnets in a cache subnet group.', 'class' => 'CacheSubnetQuotaExceededException', ), array( 'reason' => 'The requested subnet is being used by another cache subnet group.', 'class' => 'SubnetInUseException', ), array( 'reason' => 'An invalid subnet identifier was specified.', 'class' => 'InvalidSubnetException', ), ), ), 'ModifyReplicationGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplicationGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyReplicationGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReplicationGroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReplicationGroupDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheSecurityGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheSecurityGroupNames.member', 'items' => array( 'name' => 'CacheSecurityGroupName', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupIds.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NotificationTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NotificationTopicStatus' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ApplyImmediately' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PrimaryClusterId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified replication group does not exist.', 'class' => 'ReplicationGroupNotFoundException', ), array( 'reason' => 'The requested replication group is not in the available state.', 'class' => 'InvalidReplicationGroupStateException', ), array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The VPC network is in an invalid state.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'PurchaseReservedCacheNodesOffering' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedCacheNodeWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PurchaseReservedCacheNodesOffering', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReservedCacheNodesOfferingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReservedCacheNodeId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheNodeCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache node offering does not exist.', 'class' => 'ReservedCacheNodesOfferingNotFoundException', ), array( 'reason' => 'This user already has a reservation with the given identifier.', 'class' => 'ReservedCacheNodeAlreadyExistsException', ), array( 'reason' => 'The request cannot be processed because it would exceed the user\'s cache node quota.', 'class' => 'ReservedCacheNodeQuotaExceededException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'RebootCacheCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebootCacheCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CacheNodeIdsToReboot' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheNodeIdsToReboot.member', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), ), ), 'ResetCacheParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetCacheParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ResetAllParameters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ParameterNameValues' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ParameterNameValues.member', 'items' => array( 'name' => 'ParameterNameValue', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The current state of the cache parameter group does not allow the requested action to occur.', 'class' => 'InvalidCacheParameterGroupStateException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'RevokeCacheSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeCacheSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The specified Amazon EC2 security group is not authorized for the specified cache security group.', 'class' => 'AuthorizationNotFoundException', ), array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), ), 'models' => array( 'CacheSecurityGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheSecurityGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'OwnerId' => array( 'type' => 'string', ), 'CacheSecurityGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'CacheClusterWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheCluster' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CacheClusterId' => array( 'type' => 'string', ), 'ConfigurationEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ClientDownloadLandingPage' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'CacheClusterStatus' => array( 'type' => 'string', ), 'NumCacheNodes' => array( 'type' => 'numeric', ), 'PreferredAvailabilityZone' => array( 'type' => 'string', ), 'CacheClusterCreateTime' => array( 'type' => 'string', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'NumCacheNodes' => array( 'type' => 'numeric', ), 'CacheNodeIdsToRemove' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', 'sentAs' => 'CacheNodeId', ), ), 'EngineVersion' => array( 'type' => 'string', ), ), ), 'NotificationConfiguration' => array( 'type' => 'object', 'properties' => array( 'TopicArn' => array( 'type' => 'string', ), 'TopicStatus' => array( 'type' => 'string', ), ), ), 'CacheSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheSecurityGroup', 'type' => 'object', 'sentAs' => 'CacheSecurityGroup', 'properties' => array( 'CacheSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'CacheParameterGroup' => array( 'type' => 'object', 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), 'CacheNodeIdsToReboot' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', 'sentAs' => 'CacheNodeId', ), ), ), ), 'CacheSubnetGroupName' => array( 'type' => 'string', ), 'CacheNodes' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNode', 'type' => 'object', 'sentAs' => 'CacheNode', 'properties' => array( 'CacheNodeId' => array( 'type' => 'string', ), 'CacheNodeStatus' => array( 'type' => 'string', ), 'CacheNodeCreateTime' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ParameterGroupStatus' => array( 'type' => 'string', ), 'SourceCacheNodeId' => array( 'type' => 'string', ), ), ), ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', ), 'SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'SecurityGroupMembership', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'ReplicationGroupId' => array( 'type' => 'string', ), ), ), ), ), 'CacheParameterGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheParameterGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', ), 'CacheParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), 'CacheSubnetGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheSubnetGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CacheSubnetGroupName' => array( 'type' => 'string', ), 'CacheSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), 'ReplicationGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReplicationGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ReplicationGroupId' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'PrimaryClusterId' => array( 'type' => 'string', ), ), ), 'MemberClusters' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterId', 'type' => 'string', 'sentAs' => 'ClusterId', ), ), 'NodeGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'NodeGroup', 'type' => 'object', 'sentAs' => 'NodeGroup', 'properties' => array( 'NodeGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'PrimaryEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'NodeGroupMembers' => array( 'type' => 'array', 'items' => array( 'name' => 'NodeGroupMember', 'type' => 'object', 'sentAs' => 'NodeGroupMember', 'properties' => array( 'CacheClusterId' => array( 'type' => 'string', ), 'CacheNodeId' => array( 'type' => 'string', ), 'ReadEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'PreferredAvailabilityZone' => array( 'type' => 'string', ), 'CurrentRole' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CacheClusterMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheClusters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheCluster', 'type' => 'object', 'sentAs' => 'CacheCluster', 'properties' => array( 'CacheClusterId' => array( 'type' => 'string', ), 'ConfigurationEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ClientDownloadLandingPage' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'CacheClusterStatus' => array( 'type' => 'string', ), 'NumCacheNodes' => array( 'type' => 'numeric', ), 'PreferredAvailabilityZone' => array( 'type' => 'string', ), 'CacheClusterCreateTime' => array( 'type' => 'string', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'NumCacheNodes' => array( 'type' => 'numeric', ), 'CacheNodeIdsToRemove' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', 'sentAs' => 'CacheNodeId', ), ), 'EngineVersion' => array( 'type' => 'string', ), ), ), 'NotificationConfiguration' => array( 'type' => 'object', 'properties' => array( 'TopicArn' => array( 'type' => 'string', ), 'TopicStatus' => array( 'type' => 'string', ), ), ), 'CacheSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheSecurityGroup', 'type' => 'object', 'sentAs' => 'CacheSecurityGroup', 'properties' => array( 'CacheSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'CacheParameterGroup' => array( 'type' => 'object', 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), 'CacheNodeIdsToReboot' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', 'sentAs' => 'CacheNodeId', ), ), ), ), 'CacheSubnetGroupName' => array( 'type' => 'string', ), 'CacheNodes' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNode', 'type' => 'object', 'sentAs' => 'CacheNode', 'properties' => array( 'CacheNodeId' => array( 'type' => 'string', ), 'CacheNodeStatus' => array( 'type' => 'string', ), 'CacheNodeCreateTime' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ParameterGroupStatus' => array( 'type' => 'string', ), 'SourceCacheNodeId' => array( 'type' => 'string', ), ), ), ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', ), 'SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'SecurityGroupMembership', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'ReplicationGroupId' => array( 'type' => 'string', ), ), ), ), ), ), 'CacheEngineVersionMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheEngineVersions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheEngineVersion', 'type' => 'object', 'sentAs' => 'CacheEngineVersion', 'properties' => array( 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'CacheParameterGroupFamily' => array( 'type' => 'string', ), 'CacheEngineDescription' => array( 'type' => 'string', ), 'CacheEngineVersionDescription' => array( 'type' => 'string', ), ), ), ), ), ), 'CacheParameterGroupsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheParameterGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheParameterGroup', 'type' => 'object', 'sentAs' => 'CacheParameterGroup', 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', ), 'CacheParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'CacheParameterGroupDetails' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Parameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), 'CacheNodeTypeSpecificParameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheNodeTypeSpecificParameter', 'type' => 'object', 'sentAs' => 'CacheNodeTypeSpecificParameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'CacheNodeTypeSpecificValues' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeTypeSpecificValue', 'type' => 'object', 'sentAs' => 'CacheNodeTypeSpecificValue', 'properties' => array( 'CacheNodeType' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CacheSecurityGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheSecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheSecurityGroup', 'type' => 'object', 'sentAs' => 'CacheSecurityGroup', 'properties' => array( 'OwnerId' => array( 'type' => 'string', ), 'CacheSecurityGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CacheSubnetGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheSubnetGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheSubnetGroup', 'type' => 'object', 'sentAs' => 'CacheSubnetGroup', 'properties' => array( 'CacheSubnetGroupName' => array( 'type' => 'string', ), 'CacheSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'EngineDefaultsWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EngineDefaults' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CacheParameterGroupFamily' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), 'Parameters' => array( 'type' => 'array', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), 'CacheNodeTypeSpecificParameters' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeTypeSpecificParameter', 'type' => 'object', 'sentAs' => 'CacheNodeTypeSpecificParameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'CacheNodeTypeSpecificValues' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeTypeSpecificValue', 'type' => 'object', 'sentAs' => 'CacheNodeTypeSpecificValue', 'properties' => array( 'CacheNodeType' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'EventsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Events' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Event', 'type' => 'object', 'sentAs' => 'Event', 'properties' => array( 'SourceIdentifier' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'Date' => array( 'type' => 'string', ), ), ), ), ), ), 'ReplicationGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReplicationGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReplicationGroup', 'type' => 'object', 'sentAs' => 'ReplicationGroup', 'properties' => array( 'ReplicationGroupId' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'PrimaryClusterId' => array( 'type' => 'string', ), ), ), 'MemberClusters' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterId', 'type' => 'string', 'sentAs' => 'ClusterId', ), ), 'NodeGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'NodeGroup', 'type' => 'object', 'sentAs' => 'NodeGroup', 'properties' => array( 'NodeGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'PrimaryEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'NodeGroupMembers' => array( 'type' => 'array', 'items' => array( 'name' => 'NodeGroupMember', 'type' => 'object', 'sentAs' => 'NodeGroupMember', 'properties' => array( 'CacheClusterId' => array( 'type' => 'string', ), 'CacheNodeId' => array( 'type' => 'string', ), 'ReadEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'PreferredAvailabilityZone' => array( 'type' => 'string', ), 'CurrentRole' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), ), 'ReservedCacheNodeMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedCacheNodes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedCacheNode', 'type' => 'object', 'sentAs' => 'ReservedCacheNode', 'properties' => array( 'ReservedCacheNodeId' => array( 'type' => 'string', ), 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CacheNodeCount' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'State' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ReservedCacheNodesOfferingMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedCacheNodesOfferings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedCacheNodesOffering', 'type' => 'object', 'sentAs' => 'ReservedCacheNodesOffering', 'properties' => array( 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CacheParameterGroupNameMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedCacheNodeWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedCacheNode' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ReservedCacheNodeId' => array( 'type' => 'string', ), 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CacheNodeCount' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'State' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeCacheClusters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheClusters', ), 'DescribeCacheEngineVersions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheEngineVersions', ), 'DescribeCacheParameterGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheParameterGroups', ), 'DescribeCacheParameters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Parameters', ), 'DescribeCacheSecurityGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheSecurityGroups', ), 'DescribeCacheSubnetGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheSubnetGroups', ), 'DescribeEngineDefaultParameters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Parameters', ), 'DescribeEvents' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Events', ), 'DescribeReplicationGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReplicationGroups', ), 'DescribeReservedCacheNodes' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedCacheNodes', ), 'DescribeReservedCacheNodesOfferings' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedCacheNodesOfferings', ), ), ), ); sdk-2.5.2/Aws/ElasticBeanstalk/ElasticBeanstalkClient.php000064411532700161006750000001510312272324172020432 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elasticbeanstalk-%s.php' )) ->build(); } } sdk-2.5.2/Aws/ElasticBeanstalk/Enum/ConfigurationDeploymentStatus.php000064411532700161006750000000154212272324172023044 0ustar '2010-12-01', 'endpointPrefix' => 'elasticbeanstalk', 'serviceFullName' => 'AWS Elastic Beanstalk', 'serviceAbbreviation' => 'Elastic Beanstalk', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'ElasticBeanstalk', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'CheckDNSAvailability' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CheckDNSAvailabilityResultMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CheckDNSAvailability', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'CNAMEPrefix' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 63, ), ), ), 'CreateApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationDescriptionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), ), 'errorResponses' => array( array( 'reason' => 'The caller has exceeded the limit on the number of applications associated with their account.', 'class' => 'TooManyApplicationsException', ), ), ), 'CreateApplicationVersion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationVersionDescriptionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateApplicationVersion', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'SourceBundle' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'S3Bucket' => array( 'type' => 'string', 'maxLength' => 255, ), 'S3Key' => array( 'type' => 'string', 'maxLength' => 1024, ), ), ), 'AutoCreateApplication' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The caller has exceeded the limit on the number of applications associated with their account.', 'class' => 'TooManyApplicationsException', ), array( 'reason' => 'The caller has exceeded the limit on the number of application versions associated with their account.', 'class' => 'TooManyApplicationVersionsException', ), array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), array( 'reason' => 'The specified S3 bucket does not belong to the S3 region in which the service is running.', 'class' => 'S3LocationNotInServiceRegionException', ), ), ), 'CreateConfigurationTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationSettingsDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateConfigurationTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'SolutionStackName' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 100, ), 'SourceConfiguration' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 100, ), ), ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), array( 'reason' => 'The caller has exceeded the limit on the number of configuration templates associated with their account.', 'class' => 'TooManyConfigurationTemplatesException', ), ), ), 'CreateEnvironment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateEnvironment', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'CNAMEPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 63, ), 'Tier' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'SolutionStackName' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 100, ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'OptionsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToRemove.member', 'items' => array( 'name' => 'OptionSpecification', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The caller has exceeded the limit of allowed environments associated with the account.', 'class' => 'TooManyEnvironmentsException', ), array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'CreateStorageLocation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateStorageLocationResultMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateStorageLocation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), 'errorResponses' => array( array( 'reason' => 'The web service attempted to create a bucket in an Amazon S3 account that already has 100 buckets.', 'class' => 'TooManyBucketsException', ), array( 'reason' => 'The caller does not have a subscription to Amazon S3.', 'class' => 'S3SubscriptionRequiredException', ), array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'DeleteApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TerminateEnvByForce' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because another operation is already in progress affecting an an element in this activity.', 'class' => 'OperationInProgressException', ), ), ), 'DeleteApplicationVersion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteApplicationVersion', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'DeleteSourceBundle' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Unable to delete the Amazon S3 source bundle associated with the application version, although the application version deleted successfully.', 'class' => 'SourceBundleDeletionException', ), array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), array( 'reason' => 'Unable to perform the specified operation because another operation is already in progress affecting an an element in this activity.', 'class' => 'OperationInProgressException', ), array( 'reason' => 'The specified S3 bucket does not belong to the S3 region in which the service is running.', 'class' => 'S3LocationNotInServiceRegionException', ), ), ), 'DeleteConfigurationTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteConfigurationTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because another operation is already in progress affecting an an element in this activity.', 'class' => 'OperationInProgressException', ), ), ), 'DeleteEnvironmentConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteEnvironmentConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), ), 'DescribeApplicationVersions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationVersionDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeApplicationVersions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabels' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VersionLabels.member', 'items' => array( 'name' => 'VersionLabel', 'type' => 'string', 'minLength' => 1, 'maxLength' => 100, ), ), ), ), 'DescribeApplications' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeApplications', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ApplicationNames.member', 'items' => array( 'name' => 'ApplicationName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 100, ), ), ), ), 'DescribeConfigurationOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationOptionsDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeConfigurationOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'SolutionStackName' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 100, ), 'Options' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Options.member', 'items' => array( 'name' => 'OptionSpecification', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeConfigurationSettings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationSettingsDescriptions', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeConfigurationSettings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), ), 'DescribeEnvironmentResources' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentResourceDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEnvironmentResources', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'DescribeEnvironments' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEnvironments', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EnvironmentIds.member', 'items' => array( 'name' => 'EnvironmentId', 'type' => 'string', ), ), 'EnvironmentNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EnvironmentNames.member', 'items' => array( 'name' => 'EnvironmentName', 'type' => 'string', 'minLength' => 4, 'maxLength' => 23, ), ), 'IncludeDeleted' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'IncludedDeletedBackTo' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), ), ), 'DescribeEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'RequestId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Severity' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ListAvailableSolutionStacks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListAvailableSolutionStacksResultMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListAvailableSolutionStacks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), ), 'RebuildEnvironment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebuildEnvironment', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'RequestEnvironmentInfo' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RequestEnvironmentInfo', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'InfoType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'RestartAppServer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RestartAppServer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), ), 'RetrieveEnvironmentInfo' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RetrieveEnvironmentInfoResultMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RetrieveEnvironmentInfo', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'InfoType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'SwapEnvironmentCNAMEs' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SwapEnvironmentCNAMEs', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'SourceEnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceEnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'DestinationEnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DestinationEnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), ), 'TerminateEnvironment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'TerminateEnvironment', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'TerminateResources' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'UpdateApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationDescriptionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), ), ), 'UpdateApplicationVersion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationVersionDescriptionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateApplicationVersion', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), ), ), 'UpdateConfigurationTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationSettingsDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateConfigurationTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'OptionsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToRemove.member', 'items' => array( 'name' => 'OptionSpecification', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'UpdateEnvironment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateEnvironment', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'Tier' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'OptionsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToRemove.member', 'items' => array( 'name' => 'OptionSpecification', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'ValidateConfigurationSettings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationSettingsValidationMessages', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ValidateConfigurationSettings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'OptionSettings' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), ), 'models' => array( 'CheckDNSAvailabilityResultMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Available' => array( 'type' => 'boolean', 'location' => 'xml', ), 'FullyQualifiedCNAME' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ApplicationDescriptionMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Application' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), 'Versions' => array( 'type' => 'array', 'items' => array( 'name' => 'VersionLabel', 'type' => 'string', 'sentAs' => 'member', ), ), 'ConfigurationTemplates' => array( 'type' => 'array', 'items' => array( 'name' => 'ConfigurationTemplateName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), ), 'ApplicationVersionDescriptionMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ApplicationVersion' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'VersionLabel' => array( 'type' => 'string', ), 'SourceBundle' => array( 'type' => 'object', 'properties' => array( 'S3Bucket' => array( 'type' => 'string', ), 'S3Key' => array( 'type' => 'string', ), ), ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), ), ), ), ), 'ConfigurationSettingsDescription' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SolutionStackName' => array( 'type' => 'string', 'location' => 'xml', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'xml', ), 'TemplateName' => array( 'type' => 'string', 'location' => 'xml', ), 'Description' => array( 'type' => 'string', 'location' => 'xml', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'xml', ), 'DeploymentStatus' => array( 'type' => 'string', 'location' => 'xml', ), 'DateCreated' => array( 'type' => 'string', 'location' => 'xml', ), 'DateUpdated' => array( 'type' => 'string', 'location' => 'xml', ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), 'EnvironmentDescription' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EnvironmentName' => array( 'type' => 'string', 'location' => 'xml', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'xml', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'xml', ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'xml', ), 'SolutionStackName' => array( 'type' => 'string', 'location' => 'xml', ), 'TemplateName' => array( 'type' => 'string', 'location' => 'xml', ), 'Description' => array( 'type' => 'string', 'location' => 'xml', ), 'EndpointURL' => array( 'type' => 'string', 'location' => 'xml', ), 'CNAME' => array( 'type' => 'string', 'location' => 'xml', ), 'DateCreated' => array( 'type' => 'string', 'location' => 'xml', ), 'DateUpdated' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'Health' => array( 'type' => 'string', 'location' => 'xml', ), 'Resources' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'LoadBalancer' => array( 'type' => 'object', 'properties' => array( 'LoadBalancerName' => array( 'type' => 'string', ), 'Domain' => array( 'type' => 'string', ), 'Listeners' => array( 'type' => 'array', 'items' => array( 'name' => 'Listener', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Protocol' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'Tier' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), ), ), 'CreateStorageLocationResultMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'S3Bucket' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ApplicationVersionDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ApplicationVersions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ApplicationVersionDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'VersionLabel' => array( 'type' => 'string', ), 'SourceBundle' => array( 'type' => 'object', 'properties' => array( 'S3Bucket' => array( 'type' => 'string', ), 'S3Key' => array( 'type' => 'string', ), ), ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), ), ), ), ), ), 'ApplicationDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Applications' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ApplicationDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), 'Versions' => array( 'type' => 'array', 'items' => array( 'name' => 'VersionLabel', 'type' => 'string', 'sentAs' => 'member', ), ), 'ConfigurationTemplates' => array( 'type' => 'array', 'items' => array( 'name' => 'ConfigurationTemplateName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), ), ), 'ConfigurationOptionsDescription' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SolutionStackName' => array( 'type' => 'string', 'location' => 'xml', ), 'Options' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ConfigurationOptionDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'ChangeSeverity' => array( 'type' => 'string', ), 'UserDefined' => array( 'type' => 'boolean', ), 'ValueType' => array( 'type' => 'string', ), 'ValueOptions' => array( 'type' => 'array', 'items' => array( 'name' => 'ConfigurationOptionPossibleValue', 'type' => 'string', 'sentAs' => 'member', ), ), 'MinValue' => array( 'type' => 'numeric', ), 'MaxValue' => array( 'type' => 'numeric', ), 'MaxLength' => array( 'type' => 'numeric', ), 'Regex' => array( 'type' => 'object', 'properties' => array( 'Pattern' => array( 'type' => 'string', ), 'Label' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'ConfigurationSettingsDescriptions' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ConfigurationSettings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ConfigurationSettingsDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SolutionStackName' => array( 'type' => 'string', ), 'ApplicationName' => array( 'type' => 'string', ), 'TemplateName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EnvironmentName' => array( 'type' => 'string', ), 'DeploymentStatus' => array( 'type' => 'string', ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), 'OptionSettings' => array( 'type' => 'array', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'EnvironmentResourceDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EnvironmentResources' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'EnvironmentName' => array( 'type' => 'string', ), 'AutoScalingGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'AutoScalingGroup', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), 'Instances' => array( 'type' => 'array', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Id' => array( 'type' => 'string', ), ), ), ), 'LaunchConfigurations' => array( 'type' => 'array', 'items' => array( 'name' => 'LaunchConfiguration', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), 'LoadBalancers' => array( 'type' => 'array', 'items' => array( 'name' => 'LoadBalancer', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), 'Triggers' => array( 'type' => 'array', 'items' => array( 'name' => 'Trigger', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), 'Queues' => array( 'type' => 'array', 'items' => array( 'name' => 'Queue', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'URL' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EnvironmentDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Environments' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EnvironmentDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'EnvironmentName' => array( 'type' => 'string', ), 'EnvironmentId' => array( 'type' => 'string', ), 'ApplicationName' => array( 'type' => 'string', ), 'VersionLabel' => array( 'type' => 'string', ), 'SolutionStackName' => array( 'type' => 'string', ), 'TemplateName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EndpointURL' => array( 'type' => 'string', ), 'CNAME' => array( 'type' => 'string', ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Health' => array( 'type' => 'string', ), 'Resources' => array( 'type' => 'object', 'properties' => array( 'LoadBalancer' => array( 'type' => 'object', 'properties' => array( 'LoadBalancerName' => array( 'type' => 'string', ), 'Domain' => array( 'type' => 'string', ), 'Listeners' => array( 'type' => 'array', 'items' => array( 'name' => 'Listener', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Protocol' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'Tier' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EventDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Events' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'EventDate' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'ApplicationName' => array( 'type' => 'string', ), 'VersionLabel' => array( 'type' => 'string', ), 'TemplateName' => array( 'type' => 'string', ), 'EnvironmentName' => array( 'type' => 'string', ), 'RequestId' => array( 'type' => 'string', ), 'Severity' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListAvailableSolutionStacksResultMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SolutionStacks' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SolutionStackName', 'type' => 'string', 'sentAs' => 'member', ), ), 'SolutionStackDetails' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SolutionStackDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SolutionStackName' => array( 'type' => 'string', ), 'PermittedFileTypes' => array( 'type' => 'array', 'items' => array( 'name' => 'FileTypeExtension', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), ), ), 'RetrieveEnvironmentInfoResultMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EnvironmentInfo' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EnvironmentInfoDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InfoType' => array( 'type' => 'string', ), 'Ec2InstanceId' => array( 'type' => 'string', ), 'SampleTimestamp' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), 'ConfigurationSettingsValidationMessages' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Messages' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ValidationMessage', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Message' => array( 'type' => 'string', ), 'Severity' => array( 'type' => 'string', ), 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeApplicationVersions' => array( 'result_key' => 'ApplicationVersions', ), 'DescribeApplications' => array( 'result_key' => 'Applications', ), 'DescribeConfigurationOptions' => array( 'result_key' => 'Options', ), 'DescribeEnvironments' => array( 'result_key' => 'Environments', ), 'DescribeEvents' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'Events', ), 'ListAvailableSolutionStacks' => array( 'result_key' => 'SolutionStacks', ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 20, 'max_attempts' => 40, 'acceptor.type' => 'output', ), '__EnvironmentState' => array( 'operation' => 'DescribeEnvironments', 'acceptor.path' => 'Environments/*/Status', ), 'EnvironmentReady' => array( 'extends' => '__EnvironmentState', 'success.value' => 'Ready', 'failure.value' => array( 'Terminated', 'Terminating', ), ), 'EnvironmentTerminated' => array( 'extends' => '__EnvironmentState', 'success.value' => 'Terminated', 'failure.value' => array( 'Launching', 'Updating', ), ), ), ); sdk-2.5.2/Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.php000064411532700161006750000001355112272324172021763 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elasticloadbalancing-%s.php' )) ->build(); } } sdk-2.5.2/Aws/ElasticLoadBalancing/Exception/AccessPointNotFoundException.php000064411532700161006750000000140612272324172024342 0ustar '2012-06-01', 'endpointPrefix' => 'elasticloadbalancing', 'serviceFullName' => 'Elastic Load Balancing', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'ElasticLoadBalancing', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'ApplySecurityGroupsToLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplySecurityGroupsToLoadBalancerOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ApplySecurityGroupsToLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SecurityGroups' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroups.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), array( 'reason' => 'One or more specified security groups do not exist.', 'class' => 'InvalidSecurityGroupException', ), ), ), 'AttachLoadBalancerToSubnets' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AttachLoadBalancerToSubnetsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachLoadBalancerToSubnets', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Subnets' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Subnets.member', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), array( 'reason' => 'One or more subnets were not found.', 'class' => 'SubnetNotFoundException', ), array( 'reason' => 'The VPC has no Internet gateway.', 'class' => 'InvalidSubnetException', ), ), ), 'ConfigureHealthCheck' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigureHealthCheckOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ConfigureHealthCheck', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HealthCheck' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Target' => array( 'required' => true, 'type' => 'string', ), 'Interval' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, 'maximum' => 300, ), 'Timeout' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, 'maximum' => 300, ), 'UnhealthyThreshold' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 2, 'maximum' => 10, ), 'HealthyThreshold' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 2, 'maximum' => 10, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), ), ), 'CreateAppCookieStickinessPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateAppCookieStickinessPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CookieName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Policy with the same name exists for this load balancer. Please choose another name.', 'class' => 'DuplicatePolicyNameException', ), array( 'reason' => 'Quota for number of policies for this load balancer has already been reached.', 'class' => 'TooManyPoliciesException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'CreateLBCookieStickinessPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLBCookieStickinessPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CookieExpirationPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Policy with the same name exists for this load balancer. Please choose another name.', 'class' => 'DuplicatePolicyNameException', ), array( 'reason' => 'Quota for number of policies for this load balancer has already been reached.', 'class' => 'TooManyPoliciesException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'CreateLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateAccessPointOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Listeners' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Listeners.member', 'items' => array( 'name' => 'Listener', 'type' => 'object', 'properties' => array( 'Protocol' => array( 'required' => true, 'type' => 'string', ), 'LoadBalancerPort' => array( 'required' => true, 'type' => 'numeric', ), 'InstanceProtocol' => array( 'type' => 'string', ), 'InstancePort' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, 'maximum' => 65535, ), 'SSLCertificateId' => array( 'type' => 'string', ), ), ), ), 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', ), ), 'Subnets' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Subnets.member', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', ), ), 'SecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroups.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'Scheme' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Load balancer name already exists for this account. Please choose another name.', 'class' => 'DuplicateAccessPointNameException', ), array( 'reason' => 'The quota for the number of load balancers has already been reached.', 'class' => 'TooManyAccessPointsException', ), array( 'reason' => 'The specified SSL ID does not refer to a valid SSL certificate in the AWS Identity and Access Management Service.', 'class' => 'CertificateNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), array( 'reason' => 'One or more subnets were not found.', 'class' => 'SubnetNotFoundException', ), array( 'reason' => 'The VPC has no Internet gateway.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'One or more specified security groups do not exist.', 'class' => 'InvalidSecurityGroupException', ), array( 'reason' => 'Invalid value for scheme. Scheme can only be specified for load balancers in VPC.', 'class' => 'InvalidSchemeException', ), ), ), 'CreateLoadBalancerListeners' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLoadBalancerListeners', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Listeners' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Listeners.member', 'items' => array( 'name' => 'Listener', 'type' => 'object', 'properties' => array( 'Protocol' => array( 'required' => true, 'type' => 'string', ), 'LoadBalancerPort' => array( 'required' => true, 'type' => 'numeric', ), 'InstanceProtocol' => array( 'type' => 'string', ), 'InstancePort' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, 'maximum' => 65535, ), 'SSLCertificateId' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'A Listener already exists for the given LoadBalancerName and LoadBalancerPort, but with a different InstancePort, Protocol, or SSLCertificateId.', 'class' => 'DuplicateListenerException', ), array( 'reason' => 'The specified SSL ID does not refer to a valid SSL certificate in the AWS Identity and Access Management Service.', 'class' => 'CertificateNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'CreateLoadBalancerPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLoadBalancerPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyTypeName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyAttributes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyAttributes.member', 'items' => array( 'name' => 'PolicyAttribute', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeValue' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'One or more of the specified policy types do not exist.', 'class' => 'PolicyTypeNotFoundException', ), array( 'reason' => 'Policy with the same name exists for this load balancer. Please choose another name.', 'class' => 'DuplicatePolicyNameException', ), array( 'reason' => 'Quota for number of policies for this load balancer has already been reached.', 'class' => 'TooManyPoliciesException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'DeleteLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteLoadBalancerListeners' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLoadBalancerListeners', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LoadBalancerPorts' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LoadBalancerPorts.member', 'items' => array( 'name' => 'AccessPointPort', 'type' => 'numeric', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), ), ), 'DeleteLoadBalancerPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLoadBalancerPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'DeregisterInstancesFromLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeregisterEndPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeregisterInstancesFromLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Instances' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Instances.member', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified EndPoint is not valid.', 'class' => 'InvalidEndPointException', ), ), ), 'DescribeInstanceHealth' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeEndPointStateOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInstanceHealth', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Instances' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Instances.member', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified EndPoint is not valid.', 'class' => 'InvalidEndPointException', ), ), ), 'DescribeLoadBalancerAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeLoadBalancerAttributesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoadBalancerAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified load balancer attribute could not be found.', 'class' => 'LoadBalancerAttributeNotFoundException', ), ), ), 'DescribeLoadBalancerPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeLoadBalancerPoliciesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoadBalancerPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PolicyNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyNames.member', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'One or more specified policies were not found.', 'class' => 'PolicyNotFoundException', ), ), ), 'DescribeLoadBalancerPolicyTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeLoadBalancerPolicyTypesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoadBalancerPolicyTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'PolicyTypeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyTypeNames.member', 'items' => array( 'name' => 'PolicyTypeName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more of the specified policy types do not exist.', 'class' => 'PolicyTypeNotFoundException', ), ), ), 'DescribeLoadBalancers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAccessPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoadBalancers', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LoadBalancerNames.member', 'items' => array( 'name' => 'AccessPointName', 'type' => 'string', ), ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), ), ), 'DetachLoadBalancerFromSubnets' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DetachLoadBalancerFromSubnetsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachLoadBalancerFromSubnets', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Subnets' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Subnets.member', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'DisableAvailabilityZonesForLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RemoveAvailabilityZonesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableAvailabilityZonesForLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZones' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'EnableAvailabilityZonesForLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AddAvailabilityZonesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableAvailabilityZonesForLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZones' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), ), ), 'ModifyLoadBalancerAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyLoadBalancerAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LoadBalancerAttributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'CrossZoneLoadBalancing' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified load balancer attribute could not be found.', 'class' => 'LoadBalancerAttributeNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'RegisterInstancesWithLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RegisterEndPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RegisterInstancesWithLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Instances' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Instances.member', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified EndPoint is not valid.', 'class' => 'InvalidEndPointException', ), ), ), 'SetLoadBalancerListenerSSLCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetLoadBalancerListenerSSLCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LoadBalancerPort' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'SSLCertificateId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified SSL ID does not refer to a valid SSL certificate in the AWS Identity and Access Management Service.', 'class' => 'CertificateNotFoundException', ), array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Load balancer does not have a listener configured at the given port.', 'class' => 'ListenerNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'SetLoadBalancerPoliciesForBackendServer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetLoadBalancerPoliciesForBackendServer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstancePort' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'PolicyNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyNames.member', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'One or more specified policies were not found.', 'class' => 'PolicyNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'SetLoadBalancerPoliciesOfListener' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetLoadBalancerPoliciesOfListener', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LoadBalancerPort' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'PolicyNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyNames.member', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'One or more specified policies were not found.', 'class' => 'PolicyNotFoundException', ), array( 'reason' => 'Load balancer does not have a listener configured at the given port.', 'class' => 'ListenerNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), ), 'models' => array( 'ApplySecurityGroupsToLoadBalancerOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'AttachLoadBalancerToSubnetsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subnets' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'ConfigureHealthCheckOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HealthCheck' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Target' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'numeric', ), 'Timeout' => array( 'type' => 'numeric', ), 'UnhealthyThreshold' => array( 'type' => 'numeric', ), 'HealthyThreshold' => array( 'type' => 'numeric', ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreateAccessPointOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DNSName' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DeregisterEndPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Instances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeEndPointStateOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceStates' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InstanceState', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'State' => array( 'type' => 'string', ), 'ReasonCode' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeLoadBalancerAttributesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoadBalancerAttributes' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CrossZoneLoadBalancing' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeLoadBalancerPoliciesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyDescriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'PolicyDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PolicyName' => array( 'type' => 'string', ), 'PolicyTypeName' => array( 'type' => 'string', ), 'PolicyAttributeDescriptions' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyAttributeDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeValue' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeLoadBalancerPolicyTypesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyTypeDescriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'PolicyTypeDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PolicyTypeName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'PolicyAttributeTypeDescriptions' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyAttributeTypeDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Cardinality' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeAccessPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoadBalancerDescriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'LoadBalancerDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'LoadBalancerName' => array( 'type' => 'string', ), 'DNSName' => array( 'type' => 'string', ), 'CanonicalHostedZoneName' => array( 'type' => 'string', ), 'CanonicalHostedZoneNameID' => array( 'type' => 'string', ), 'ListenerDescriptions' => array( 'type' => 'array', 'items' => array( 'name' => 'ListenerDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Listener' => array( 'type' => 'object', 'properties' => array( 'Protocol' => array( 'type' => 'string', ), 'LoadBalancerPort' => array( 'type' => 'numeric', ), 'InstanceProtocol' => array( 'type' => 'string', ), 'InstancePort' => array( 'type' => 'numeric', ), 'SSLCertificateId' => array( 'type' => 'string', ), ), ), 'PolicyNames' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), 'Policies' => array( 'type' => 'object', 'properties' => array( 'AppCookieStickinessPolicies' => array( 'type' => 'array', 'items' => array( 'name' => 'AppCookieStickinessPolicy', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PolicyName' => array( 'type' => 'string', ), 'CookieName' => array( 'type' => 'string', ), ), ), ), 'LBCookieStickinessPolicies' => array( 'type' => 'array', 'items' => array( 'name' => 'LBCookieStickinessPolicy', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PolicyName' => array( 'type' => 'string', ), 'CookieExpirationPeriod' => array( 'type' => 'numeric', ), ), ), ), 'OtherPolicies' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'BackendServerDescriptions' => array( 'type' => 'array', 'items' => array( 'name' => 'BackendServerDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstancePort' => array( 'type' => 'numeric', ), 'PolicyNames' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', 'sentAs' => 'member', ), ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', 'sentAs' => 'member', ), ), 'VPCId' => array( 'type' => 'string', ), 'Instances' => array( 'type' => 'array', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), 'HealthCheck' => array( 'type' => 'object', 'properties' => array( 'Target' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'numeric', ), 'Timeout' => array( 'type' => 'numeric', ), 'UnhealthyThreshold' => array( 'type' => 'numeric', ), 'HealthyThreshold' => array( 'type' => 'numeric', ), ), ), 'SourceSecurityGroup' => array( 'type' => 'object', 'properties' => array( 'OwnerAlias' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), ), ), 'SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', 'sentAs' => 'member', ), ), 'CreatedTime' => array( 'type' => 'string', ), 'Scheme' => array( 'type' => 'string', ), ), ), ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DetachLoadBalancerFromSubnetsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subnets' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'RemoveAvailabilityZonesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'AddAvailabilityZonesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'RegisterEndPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Instances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeInstanceHealth' => array( 'result_key' => 'InstanceStates', ), 'DescribeLoadBalancerPolicies' => array( 'result_key' => 'PolicyDescriptions', ), 'DescribeLoadBalancerPolicyTypes' => array( 'result_key' => 'PolicyTypeDescriptions', ), 'DescribeLoadBalancers' => array( 'token_param' => 'Marker', 'token_key' => 'NextMarker', 'result_key' => 'LoadBalancerDescriptions', ), ), ), ); sdk-2.5.2/Aws/ElasticTranscoder/ElasticTranscoderClient.php000064411532700161006750000001043312272324172021033 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elastictranscoder-%s.php' )) ->setExceptionParser(new JsonRestExceptionParser()) ->build(); } } sdk-2.5.2/Aws/ElasticTranscoder/Exception/AccessDeniedException.php000064411532700161006750000000141712272324172022414 0ustar '2012-09-25', 'endpointPrefix' => 'elastictranscoder', 'serviceFullName' => 'Amazon Elastic Transcoder', 'serviceType' => 'rest-json', 'signatureVersion' => 'v4', 'namespace' => 'ElasticTranscoder', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'CancelJob' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-09-25/jobs/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'CreateJob' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/jobs', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateJobResponse', 'responseType' => 'model', 'parameters' => array( 'PipelineId' => array( 'type' => 'string', 'location' => 'json', ), 'Input' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Key' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Key' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 40, ), 'InputKey' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 30, 'items' => array( 'name' => 'CreateJobOutput', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 40, ), 'InputKey' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), 'Playlists' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 30, 'items' => array( 'name' => 'CreateJobPlaylist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Key', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Too many operations for a given AWS account. For example, the number of pipelines exceeds the maximum allowed.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'CreatePipeline' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/pipelines', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreatePipelineResponse', 'responseType' => 'model', 'parameters' => array( 'Name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 40, ), 'InputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'OutputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'Role' => array( 'type' => 'string', 'location' => 'json', ), 'Notifications' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Access' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Access' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Too many operations for a given AWS account. For example, the number of pipelines exceeds the maximum allowed.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'CreatePreset' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/presets', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreatePresetResponse', 'responseType' => 'model', 'parameters' => array( 'Name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 40, ), 'Description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 255, ), 'Container' => array( 'type' => 'string', 'location' => 'json', ), 'Video' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, 'data' => array( 'shape_name' => 'CodecOption', ), ), ), 'KeyframesMaxDist' => array( 'type' => 'string', ), 'FixedGOP' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'MaxFrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'DisplayAspectRatio' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'PresetWatermark', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 40, ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'HorizontalAlign' => array( 'type' => 'string', ), 'HorizontalOffset' => array( 'type' => 'string', ), 'VerticalAlign' => array( 'type' => 'string', ), 'VerticalOffset' => array( 'type' => 'string', ), 'Opacity' => array( 'type' => 'string', ), 'Target' => array( 'type' => 'string', ), ), ), ), ), ), 'Audio' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'SampleRate' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'Channels' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'properties' => array( 'Profile' => array( 'type' => 'string', ), ), ), ), ), 'Thumbnails' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Too many operations for a given AWS account. For example, the number of pipelines exceeds the maximum allowed.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'DeletePipeline' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-09-25/pipelines/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'DeletePreset' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-09-25/presets/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ListJobsByPipeline' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/jobsByPipeline/{PipelineId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListJobsByPipelineResponse', 'responseType' => 'model', 'parameters' => array( 'PipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Ascending' => array( 'type' => 'string', 'location' => 'query', ), 'PageToken' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ListJobsByStatus' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/jobsByStatus/{Status}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListJobsByStatusResponse', 'responseType' => 'model', 'parameters' => array( 'Status' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Ascending' => array( 'type' => 'string', 'location' => 'query', ), 'PageToken' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ListPipelines' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/pipelines', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListPipelinesResponse', 'responseType' => 'model', 'parameters' => array( 'Ascending' => array( 'type' => 'string', 'location' => 'query', ), 'PageToken' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ListPresets' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/presets', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListPresetsResponse', 'responseType' => 'model', 'parameters' => array( 'Ascending' => array( 'type' => 'string', 'location' => 'query', ), 'PageToken' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ReadJob' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/jobs/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ReadJobResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ReadPipeline' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/pipelines/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ReadPipelineResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ReadPreset' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/presets/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ReadPresetResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'TestRole' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/roleTests', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'TestRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Role' => array( 'type' => 'string', 'location' => 'json', ), 'InputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'OutputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'Topics' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 30, 'items' => array( 'name' => 'SnsTopic', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'UpdatePipeline' => array( 'httpMethod' => 'PUT', 'uri' => '/2012-09-25/pipelines/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdatePipelineResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 40, ), 'InputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'Role' => array( 'type' => 'string', 'location' => 'json', ), 'Notifications' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Access' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Access' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'UpdatePipelineNotifications' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/pipelines/{Id}/notifications', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdatePipelineNotificationsResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Notifications' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'UpdatePipelineStatus' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/pipelines/{Id}/status', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdatePipelineStatusResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Status' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreateJobResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Job' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'PipelineId' => array( 'type' => 'string', ), 'Input' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'JobOutput', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', ), 'Playlists' => array( 'type' => 'array', 'items' => array( 'name' => 'Playlist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), ), ), ), ), 'CreatePipelineResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'CreatePresetResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Preset' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), 'Audio' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'SampleRate' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'Channels' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'properties' => array( 'Profile' => array( 'type' => 'string', ), ), ), ), ), 'Video' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'KeyframesMaxDist' => array( 'type' => 'string', ), 'FixedGOP' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'MaxFrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'DisplayAspectRatio' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'PresetWatermark', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'HorizontalAlign' => array( 'type' => 'string', ), 'HorizontalOffset' => array( 'type' => 'string', ), 'VerticalAlign' => array( 'type' => 'string', ), 'VerticalOffset' => array( 'type' => 'string', ), 'Opacity' => array( 'type' => 'string', ), 'Target' => array( 'type' => 'string', ), ), ), ), ), ), 'Thumbnails' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), ), ), 'Type' => array( 'type' => 'string', ), ), ), 'Warning' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListJobsByPipelineResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Jobs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Job', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'PipelineId' => array( 'type' => 'string', ), 'Input' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'JobOutput', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', ), 'Playlists' => array( 'type' => 'array', 'items' => array( 'name' => 'Playlist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), ), ), ), 'NextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListJobsByStatusResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Jobs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Job', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'PipelineId' => array( 'type' => 'string', ), 'Input' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'JobOutput', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', ), 'Playlists' => array( 'type' => 'array', 'items' => array( 'name' => 'Playlist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), ), ), ), 'NextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListPipelinesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipelines' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Pipeline', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), 'NextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListPresetsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Presets' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Preset', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), 'Audio' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'SampleRate' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'Channels' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'properties' => array( 'Profile' => array( 'type' => 'string', ), ), ), ), ), 'Video' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'KeyframesMaxDist' => array( 'type' => 'string', ), 'FixedGOP' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'MaxFrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'DisplayAspectRatio' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'PresetWatermark', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'HorizontalAlign' => array( 'type' => 'string', ), 'HorizontalOffset' => array( 'type' => 'string', ), 'VerticalAlign' => array( 'type' => 'string', ), 'VerticalOffset' => array( 'type' => 'string', ), 'Opacity' => array( 'type' => 'string', ), 'Target' => array( 'type' => 'string', ), ), ), ), ), ), 'Thumbnails' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), ), ), 'Type' => array( 'type' => 'string', ), ), ), ), 'NextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ReadJobResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Job' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'PipelineId' => array( 'type' => 'string', ), 'Input' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'JobOutput', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', ), 'Playlists' => array( 'type' => 'array', 'items' => array( 'name' => 'Playlist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), ), ), ), ), 'ReadPipelineResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'ReadPresetResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Preset' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), 'Audio' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'SampleRate' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'Channels' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'properties' => array( 'Profile' => array( 'type' => 'string', ), ), ), ), ), 'Video' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'KeyframesMaxDist' => array( 'type' => 'string', ), 'FixedGOP' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'MaxFrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'DisplayAspectRatio' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'PresetWatermark', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'HorizontalAlign' => array( 'type' => 'string', ), 'HorizontalOffset' => array( 'type' => 'string', ), 'VerticalAlign' => array( 'type' => 'string', ), 'VerticalOffset' => array( 'type' => 'string', ), 'Opacity' => array( 'type' => 'string', ), 'Target' => array( 'type' => 'string', ), ), ), ), ), ), 'Thumbnails' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), ), ), 'Type' => array( 'type' => 'string', ), ), ), ), ), 'TestRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Success' => array( 'type' => 'string', 'location' => 'json', ), 'Messages' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'UpdatePipelineResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'UpdatePipelineNotificationsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'UpdatePipelineStatusResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'ListJobsByPipeline' => array( 'token_param' => 'PageToken', 'token_key' => 'NextPageToken', 'result_key' => 'Jobs', ), 'ListJobsByStatus' => array( 'token_param' => 'PageToken', 'token_key' => 'NextPageToken', 'result_key' => 'Jobs', ), 'ListPipelines' => array( 'token_param' => 'PageToken', 'token_key' => 'NextPageToken', 'result_key' => 'Pipelines', ), 'ListPresets' => array( 'token_param' => 'PageToken', 'token_key' => 'NextPageToken', 'result_key' => 'Presets', ), ), ), ); sdk-2.5.2/Aws/Emr/EmrClient.php000064411532700161006750000001051312272324172013256 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/emr-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } sdk-2.5.2/Aws/Emr/Enum/ActionOnFailure.php000064411532700161006750000000163512272324172015327 0ustar '2009-03-31', 'endpointPrefix' => 'elasticmapreduce', 'serviceFullName' => 'Amazon Elastic MapReduce', 'serviceAbbreviation' => 'Amazon EMR', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'ElasticMapReduce.', 'timestampFormat' => 'unixTimestamp', 'signatureVersion' => 'v4', 'namespace' => 'Emr', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AddInstanceGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddInstanceGroupsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.AddInstanceGroups', ), 'InstanceGroups' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'InstanceGroupConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', 'maxLength' => 256, ), 'Market' => array( 'type' => 'string', ), 'InstanceRole' => array( 'required' => true, 'type' => 'string', ), 'BidPrice' => array( 'type' => 'string', 'maxLength' => 256, ), 'InstanceType' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'InstanceCount' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), 'JobFlowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'AddJobFlowSteps' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddJobFlowStepsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.AddJobFlowSteps', ), 'JobFlowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'Steps' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StepConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'maxLength' => 256, ), 'ActionOnFailure' => array( 'type' => 'string', ), 'HadoopJarStep' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Properties' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyValue', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', 'maxLength' => 10280, ), 'Value' => array( 'type' => 'string', 'maxLength' => 10280, ), ), ), ), 'Jar' => array( 'required' => true, 'type' => 'string', 'maxLength' => 10280, ), 'MainClass' => array( 'type' => 'string', 'maxLength' => 10280, ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'AddTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.AddTags', ), 'ResourceId' => array( 'type' => 'string', 'location' => 'json', ), 'Tags' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'DescribeCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeClusterOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.DescribeCluster', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'DescribeJobFlows' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeJobFlowsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.DescribeJobFlows', ), 'CreatedAfter' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', 'location' => 'json', ), 'CreatedBefore' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', 'location' => 'json', ), 'JobFlowIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), 'JobFlowStates' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'JobFlowExecutionState', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeStep' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStepOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.DescribeStep', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'StepId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListBootstrapActions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListBootstrapActionsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListBootstrapActions', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListClusters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListClustersOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListClusters', ), 'CreatedAfter' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', 'location' => 'json', ), 'CreatedBefore' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', 'location' => 'json', ), 'ClusterStates' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ClusterState', 'type' => 'string', ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListInstanceGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListInstanceGroupsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListInstanceGroups', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListInstancesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListInstances', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceGroupId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceGroupTypes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'InstanceGroupType', 'type' => 'string', ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListSteps' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListStepsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListSteps', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'StepStates' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StepState', 'type' => 'string', ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ModifyInstanceGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ModifyInstanceGroups', ), 'InstanceGroups' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'InstanceGroupModifyConfig', 'type' => 'object', 'properties' => array( 'InstanceGroupId' => array( 'required' => true, 'type' => 'string', 'maxLength' => 256, ), 'InstanceCount' => array( 'type' => 'numeric', ), 'EC2InstanceIdsToTerminate' => array( 'type' => 'array', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'RemoveTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.RemoveTags', ), 'ResourceId' => array( 'type' => 'string', 'location' => 'json', ), 'TagKeys' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'RunJobFlow' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RunJobFlowOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.RunJobFlow', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'LogUri' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 10280, ), 'AdditionalInfo' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 10280, ), 'AmiVersion' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'Instances' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'MasterInstanceType' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'SlaveInstanceType' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'InstanceCount' => array( 'type' => 'numeric', ), 'InstanceGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'InstanceGroupConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', 'maxLength' => 256, ), 'Market' => array( 'type' => 'string', ), 'InstanceRole' => array( 'required' => true, 'type' => 'string', ), 'BidPrice' => array( 'type' => 'string', 'maxLength' => 256, ), 'InstanceType' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'InstanceCount' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), 'Ec2KeyName' => array( 'type' => 'string', 'maxLength' => 256, ), 'Placement' => array( 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'required' => true, 'type' => 'string', 'maxLength' => 10280, ), ), ), 'KeepJobFlowAliveWhenNoSteps' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'TerminationProtected' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'HadoopVersion' => array( 'type' => 'string', 'maxLength' => 256, ), 'Ec2SubnetId' => array( 'type' => 'string', 'maxLength' => 256, ), ), ), 'Steps' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StepConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'maxLength' => 256, ), 'ActionOnFailure' => array( 'type' => 'string', ), 'HadoopJarStep' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Properties' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyValue', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', 'maxLength' => 10280, ), 'Value' => array( 'type' => 'string', 'maxLength' => 10280, ), ), ), ), 'Jar' => array( 'required' => true, 'type' => 'string', 'maxLength' => 10280, ), 'MainClass' => array( 'type' => 'string', 'maxLength' => 10280, ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), ), ), ), ), 'BootstrapActions' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'BootstrapActionConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'maxLength' => 256, ), 'ScriptBootstrapAction' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Path' => array( 'required' => true, 'type' => 'string', 'maxLength' => 10280, ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), ), ), ), ), 'SupportedProducts' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlStringMaxLen256', 'type' => 'string', 'maxLength' => 256, ), ), 'NewSupportedProducts' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'SupportedProductConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', 'maxLength' => 256, ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), ), ), 'VisibleToAllUsers' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'JobFlowRole' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 10280, ), 'Tags' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'SetTerminationProtection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.SetTerminationProtection', ), 'JobFlowIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), 'TerminationProtected' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'SetVisibleToAllUsers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.SetVisibleToAllUsers', ), 'JobFlowIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), 'VisibleToAllUsers' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'TerminateJobFlows' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.TerminateJobFlows', ), 'JobFlowIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), ), 'models' => array( 'AddInstanceGroupsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobFlowId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceGroupIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlStringMaxLen256', 'type' => 'string', ), ), ), ), 'AddJobFlowStepsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StepIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlStringMaxLen256', 'type' => 'string', ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeClusterOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Cluster' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), 'Ec2InstanceAttributes' => array( 'type' => 'object', 'properties' => array( 'Ec2KeyName' => array( 'type' => 'string', ), 'Ec2SubnetId' => array( 'type' => 'string', ), 'Ec2AvailabilityZone' => array( 'type' => 'string', ), 'IamInstanceProfile' => array( 'type' => 'string', ), ), ), 'LogUri' => array( 'type' => 'string', ), 'RequestedAmiVersion' => array( 'type' => 'string', ), 'RunningAmiVersion' => array( 'type' => 'string', ), 'AutoTerminate' => array( 'type' => 'boolean', ), 'TerminationProtected' => array( 'type' => 'boolean', ), 'VisibleToAllUsers' => array( 'type' => 'boolean', ), 'Applications' => array( 'type' => 'array', 'items' => array( 'name' => 'Application', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'AdditionalInfo' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), ), ), ), 'Tags' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DescribeJobFlowsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobFlows' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'JobFlowDetail', 'type' => 'object', 'properties' => array( 'JobFlowId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'LogUri' => array( 'type' => 'string', ), 'AmiVersion' => array( 'type' => 'string', ), 'ExecutionStatusDetail' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), 'LastStateChangeReason' => array( 'type' => 'string', ), ), ), 'Instances' => array( 'type' => 'object', 'properties' => array( 'MasterInstanceType' => array( 'type' => 'string', ), 'MasterPublicDnsName' => array( 'type' => 'string', ), 'MasterInstanceId' => array( 'type' => 'string', ), 'SlaveInstanceType' => array( 'type' => 'string', ), 'InstanceCount' => array( 'type' => 'numeric', ), 'InstanceGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'InstanceGroupDetail', 'type' => 'object', 'properties' => array( 'InstanceGroupId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Market' => array( 'type' => 'string', ), 'InstanceRole' => array( 'type' => 'string', ), 'BidPrice' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'InstanceRequestCount' => array( 'type' => 'numeric', ), 'InstanceRunningCount' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'LastStateChangeReason' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), 'NormalizedInstanceHours' => array( 'type' => 'numeric', ), 'Ec2KeyName' => array( 'type' => 'string', ), 'Ec2SubnetId' => array( 'type' => 'string', ), 'Placement' => array( 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), ), ), 'KeepJobFlowAliveWhenNoSteps' => array( 'type' => 'boolean', ), 'TerminationProtected' => array( 'type' => 'boolean', ), 'HadoopVersion' => array( 'type' => 'string', ), ), ), 'Steps' => array( 'type' => 'array', 'items' => array( 'name' => 'StepDetail', 'type' => 'object', 'properties' => array( 'StepConfig' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ActionOnFailure' => array( 'type' => 'string', ), 'HadoopJarStep' => array( 'type' => 'object', 'properties' => array( 'Properties' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyValue', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'Jar' => array( 'type' => 'string', ), 'MainClass' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), ), ), ), ), 'ExecutionStatusDetail' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), 'LastStateChangeReason' => array( 'type' => 'string', ), ), ), ), ), ), 'BootstrapActions' => array( 'type' => 'array', 'items' => array( 'name' => 'BootstrapActionDetail', 'type' => 'object', 'properties' => array( 'BootstrapActionConfig' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ScriptBootstrapAction' => array( 'type' => 'object', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), ), ), ), ), ), ), ), 'SupportedProducts' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlStringMaxLen256', 'type' => 'string', ), ), 'VisibleToAllUsers' => array( 'type' => 'boolean', ), 'JobFlowRole' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeStepOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Step' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Config' => array( 'type' => 'object', 'properties' => array( 'Jar' => array( 'type' => 'string', ), 'Properties' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'MainClass' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'ActionOnFailure' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ListBootstrapActionsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'BootstrapActions' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Command', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ScriptPath' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListClustersOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Clusters' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ClusterSummary', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListInstanceGroupsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceGroups' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'InstanceGroup', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Market' => array( 'type' => 'string', ), 'InstanceGroupType' => array( 'type' => 'string', ), 'BidPrice' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'RequestedInstanceCount' => array( 'type' => 'numeric', ), 'RunningInstanceCount' => array( 'type' => 'numeric', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListInstancesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Instances' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Ec2InstanceId' => array( 'type' => 'string', ), 'PublicDnsName' => array( 'type' => 'string', ), 'PublicIpAddress' => array( 'type' => 'string', ), 'PrivateDnsName' => array( 'type' => 'string', ), 'PrivateIpAddress' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListStepsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Steps' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StepSummary', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'RunJobFlowOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobFlowId' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeJobFlows' => array( 'result_key' => 'JobFlows', ), 'ListBootstrapActions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'BootstrapActions', ), 'ListClusters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'Clusters', ), 'ListInstanceGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'InstanceGroups', ), 'ListInstances' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'Instances', ), 'ListSteps' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'Steps', ), ), ), ); sdk-2.5.2/Aws/Glacier/GlacierClient.php000064411532700161006750000001441212272324172014726 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/glacier-%s.php', // Set default value for "accountId" for all requests 'command.params' => array( 'accountId' => '-', Options::MODEL_PROCESSING => true ) )) ->setExceptionParser(new JsonRestExceptionParser()) ->setIteratorsConfig(array( 'limit_param' => 'limit', 'token_param' => 'marker', 'token_key' => 'Marker', 'operations' => array( 'ListJobs' => array( 'result_key' => 'JobList' ), 'ListMultipartUploads' => array( 'result_key' => 'UploadsList' ), 'ListParts' => array( 'result_key' => 'Parts' ), 'ListVaults' => array( 'result_key' => 'VaultList' ) ) )) ->build(); // Add the Glacier version header required for all operations $client->getConfig()->setPath( 'request.options/headers/x-amz-glacier-version', $client->getDescription()->getApiVersion() ); // Allow for specifying bodies with file paths and file handles $uploadOperations = array('UploadArchive', 'UploadMultipartPart'); $client->addSubscriber(new UploadBodyListener($uploadOperations, 'body', 'sourceFile')); // Listen for upload operations and make sure the required hash headers are added $client->addSubscriber(new GlacierUploadListener()); return $client; } } sdk-2.5.2/Aws/Glacier/GlacierUploadListener.php000064411532700161006750000000426712272324172016451 0ustar array('onCommandBeforeSend'), ); } /** * Retrieve bodies passed in as UploadPartContext objects and set the real hash, length, etc. values on the command * * @param Event $event Event emitted */ public function onCommandBeforeSend(Event $event) { /** @var $command AbstractCommand */ $command = $event['command']; $contentHash = $command->get('ContentSHA256'); if ($contentHash === true) { /** @var $request EntityEnclosingRequest */ $request = $command->getRequest(); $upload = UploadPartGenerator::createSingleUploadPart($request->getBody()); $request->addHeader('x-amz-content-sha256', $upload->getContentHash()); if (!$command->get('checksum')) { $request->addHeader('x-amz-sha256-tree-hash', $upload->getChecksum()); } } elseif (is_string($contentHash)) { $request = $command->getRequest(); $request->addHeader('x-amz-content-sha256', $contentHash); } } } sdk-2.5.2/Aws/Glacier/Enum/Action.php000064411532700161006750000000157212272324172014345 0ustar state->getPartGenerator()->getPartSize(); } /** * {@inheritdoc} */ protected function complete() { $partGenerator = $this->state->getPartGenerator(); $params = array_replace($this->state->getUploadId()->toParams(), array( 'archiveSize' => $partGenerator->getArchiveSize(), 'checksum' => $partGenerator->getRootChecksum(), Ua::OPTION => Ua::MULTIPART_UPLOAD )); $command = $this->client->getCommand('CompleteMultipartUpload', $params); return $command->getResult(); } /** * {@inheritdoc} */ protected function getAbortCommand() { $params = $this->state->getUploadId()->toParams(); $params[Ua::OPTION] = Ua::MULTIPART_UPLOAD; /** @var $command OperationCommand */ $command = $this->client->getCommand('AbortMultipartUpload', $params); return $command; } /** * Creates an UploadMultipartPart command from an UploadPart object * * @param UploadPart $part UploadPart for which to create a command * @param bool $useSourceCopy Whether or not to use the original source or a copy of it * * @return OperationCommand */ protected function getCommandForPart(UploadPart $part, $useSourceCopy = false) { // Setup the command with identifying parameters (accountId, vaultName, and uploadId) /** @var $command OperationCommand */ $command = $this->client->getCommand('UploadMultipartPart', $this->state->getUploadId()->toParams()); $command->set(Ua::OPTION, Ua::MULTIPART_UPLOAD); // Get the correct source $source = $this->source; if ($useSourceCopy) { $sourceUri = $this->source->getUri(); $source = new EntityBody(fopen($sourceUri, 'r')); } // Add the range, checksum, and the body limited by the range $command->set('range', $part->getFormattedRange()); $command->set('checksum', $part->getChecksum()); $command->set('ContentSHA256', $part->getContentHash()); $command->set('body', new ReadLimitEntityBody($source, $part->getSize(), $part->getOffset())); return $command; } } sdk-2.5.2/Aws/Glacier/Model/MultipartUpload/ParallelTransfer.php000064411532700161006750000000503312272324172021647 0ustar source->isLocal() || $this->source->getWrapper() != 'plainfile') { throw new RuntimeException('The source data must be a local file stream when uploading in parallel.'); } if (empty($this->options['concurrency'])) { throw new RuntimeException('The `concurrency` option must be specified when instantiating.'); } } /** * {@inheritdoc} */ protected function transfer() { /** @var $parts UploadPartGenerator */ $parts = $this->state->getPartGenerator(); $chunkSize = min($this->options['concurrency'], count($parts)); $partSets = new ChunkedIterator($parts, $chunkSize); foreach ($partSets as $partSet) { /** @var $part UploadPart */ $commands = array(); foreach ($partSet as $index => $part) { $command = $this->getCommandForPart($part, (bool) $index)->set('part', $part); $this->dispatch(self::BEFORE_PART_UPLOAD, $this->getEventData($command)); $commands[] = $command; } // Allow listeners to stop the transfer if needed if ($this->stopped) { break; } // Execute each command, iterate over the results, and add to the transfer state /** @var $command \Guzzle\Service\Command\OperationCommand */ foreach ($this->client->execute($commands) as $command) { $this->state->addPart($command->get('part')); $this->dispatch(self::AFTER_PART_UPLOAD, $this->getEventData($command)); } } } } sdk-2.5.2/Aws/Glacier/Model/MultipartUpload/SerialTransfer.php000064411532700161006750000000312012272324172021325 0ustar state->getPartGenerator(); /** @var $part UploadPart */ foreach ($partGenerator as $part) { $command = $this->getCommandForPart($part); // Notify observers that the part is about to be uploaded $eventData = $this->getEventData($command); $this->dispatch(self::BEFORE_PART_UPLOAD, $eventData); // Allow listeners to stop the transfer if needed if ($this->stopped) { break; } $command->execute(); $this->state->addPart($part); // Notify observers that the part was uploaded $this->dispatch(self::AFTER_PART_UPLOAD, $eventData); } } } sdk-2.5.2/Aws/Glacier/Model/MultipartUpload/TransferState.php000064411532700161006750000000466512272324172021205 0ustar getIterator('ListParts', $uploadId->toParams()); foreach ($listParts as $part) { list($firstByte, $lastByte) = explode('-', $part['RangeInBytes']); $partSize = (float) $listParts->getLastResult()->get('PartSizeInBytes'); $partData = array( 'partNumber' => $firstByte / $partSize + 1, 'checksum' => $part['SHA256TreeHash'], 'contentHash' => self::ALREADY_UPLOADED, 'size' => $lastByte - $firstByte + 1, 'offset' => $firstByte ); $transferState->addPart(UploadPart::fromArray($partData)); } return $transferState; } /** * @param UploadPartGenerator $partGenerator Glacier upload helper object * * @return self */ public function setPartGenerator(UploadPartGenerator $partGenerator) { $this->partGenerator = $partGenerator; return $this; } /** * @return UploadPartGenerator Glacier upload helper object */ public function getPartGenerator() { return $this->partGenerator; } } sdk-2.5.2/Aws/Glacier/Model/MultipartUpload/UploadBuilder.php000064411532700161006750000001466012272324172021147 0ustar accountId = $accountId; return $this; } /** * Set the vault name to upload the part to * * @param string $vaultName Name of the vault * * @return self */ public function setVaultName($vaultName) { $this->vaultName = $vaultName; return $this; } /** * Set the upload part size * * @param int $partSize Upload part size * * @return self */ public function setPartSize($partSize) { $this->partSize = (int) $partSize; return $this; } /** * Set the archive description * * @param string $archiveDescription Archive description * * @return self */ public function setArchiveDescription($archiveDescription) { $this->archiveDescription = $archiveDescription; return $this; } /** * Set the concurrency level to use when uploading parts. This affects how many parts are uploaded in parallel. You * must use a local file as your data source when using a concurrency greater than 1 * * @param int $concurrency Concurrency level * * @return self */ public function setConcurrency($concurrency) { $this->concurrency = $concurrency; return $this; } /** * Sets the Glacier upload helper object that pre-calculates hashes and sizes for all upload parts * * @param UploadPartGenerator $partGenerator Glacier upload helper object * * @return self */ public function setPartGenerator(UploadPartGenerator $partGenerator) { $this->partGenerator = $partGenerator; return $this; } /** * {@inheritdoc} * @throws InvalidArgumentException when attempting to resume a transfer using a non-seekable stream * @throws InvalidArgumentException when missing required properties (bucket, key, client, source) */ public function build() { // If a Glacier upload helper object was set, use the source and part size from it if ($this->partGenerator) { $this->partSize = $this->partGenerator->getPartSize(); } if (!($this->state instanceof State) && !$this->vaultName || !$this->client || !$this->source) { throw new InvalidArgumentException('You must specify a vault name, client, and source.'); } if (!$this->source->isSeekable()) { throw new InvalidArgumentException('You cannot upload from a non-seekable source.'); } // If no state was set, then create one by initiating or loading a multipart upload if (is_string($this->state)) { if (!$this->partGenerator) { throw new InvalidArgumentException('You must provide an UploadPartGenerator when resuming an upload.'); } /** @var $state \Aws\Glacier\Model\MultipartUpload\TransferState */ $this->state = TransferState::fromUploadId($this->client, UploadId::fromParams(array( 'accountId' => $this->accountId, 'vaultName' => $this->vaultName, 'uploadId' => $this->state ))); $this->state->setPartGenerator($this->partGenerator); } elseif (!$this->state) { $this->state = $this->initiateMultipartUpload(); } $options = array( 'concurrency' => $this->concurrency ); return $this->concurrency > 1 ? new ParallelTransfer($this->client, $this->state, $this->source, $options) : new SerialTransfer($this->client, $this->state, $this->source, $options); } /** * {@inheritdoc} */ protected function initiateMultipartUpload() { $params = array( 'accountId' => $this->accountId, 'vaultName' => $this->vaultName ); $partGenerator = $this->partGenerator ?: UploadPartGenerator::factory($this->source, $this->partSize); $command = $this->client->getCommand('InitiateMultipartUpload', array_replace($params, array( 'command.headers' => $this->headers, 'partSize' => $partGenerator->getPartSize(), 'archiveDescription' => $this->archiveDescription, Ua::OPTION => Ua::MULTIPART_UPLOAD ))); $params['uploadId'] = $command->getResult()->get('uploadId'); // Create a new state based on the initiated upload $state = new TransferState(UploadId::fromParams($params)); $state->setPartGenerator($partGenerator); return $state; } } sdk-2.5.2/Aws/Glacier/Model/MultipartUpload/UploadId.php000064411532700161006750000000177612272324172020121 0ustar '-', 'uploadId' => false, 'vaultName' => false ); } sdk-2.5.2/Aws/Glacier/Model/MultipartUpload/UploadPart.php000064411532700161006750000000463612272324172020471 0ustar 'partNumber', 'checksum' => 'checksum', 'contentHash' => 'contentHash', 'size' => 'size', 'offset' => 'offset' ); /** * @var string The sha256 tree hash of the upload body */ protected $checksum; /** * @var string The sha256 linear hash of the upload body */ protected $contentHash; /** * @var int The size (or content-length) in bytes of the upload body */ protected $size; /** * @var int The starting offset byte of the upload body */ protected $offset; /** * @return string */ public function getChecksum() { return $this->checksum; } /** * @return string */ public function getContentHash() { return $this->contentHash; } /** * @return int */ public function getSize() { return $this->size; } /** * @return int */ public function getOffset() { return $this->offset; } /** * Returns the byte range of the part as an array * * @return array */ public function getRange() { return array($this->offset, $this->offset + $this->size - 1); } /** * Returns the byte range ot the part formatted for the Content-Range header * * @return string */ public function getFormattedRange() { list($firstByte, $lastByte) = $this->getRange(); return "bytes {$firstByte}-{$lastByte}/*"; } } sdk-2.5.2/Aws/Glacier/Model/MultipartUpload/UploadPartContext.php000064411532700161006750000000717212272324172022034 0ustar maxSize = $maxSize; $this->offset = $offset; $this->size = 0; $this->treeHash = new TreeHash(); $this->chunkHash = new ChunkHash(); } /** * Adds data to the context. This adds data to both the tree and chunk hashes and increases the size * * @param string $data Data to add to the context * * @return self * @throws LogicException when the context is already finalized */ public function addData($data) { $size = strlen($data); if ($this->size + $size > $this->maxSize) { throw new LogicException('You cannot add data that will exceed the maximum size of this upload.'); } try { $this->treeHash->addData($data); $this->chunkHash->addData($data); $this->size += $size; } catch (LogicException $e) { throw new LogicException('You cannot add data to a finalized UploadPartContext.', 0, $e); } return $this; } /** * Finalizes the context by calculating the final hashes and generates an upload part object * * @return UploadPart */ public function generatePart() { if (!$this->uploadPart) { $this->uploadPart = UploadPart::fromArray(array( 'partNumber' => (int) ($this->offset / $this->maxSize + 1), 'checksum' => $this->treeHash->getHash(), 'contentHash' => $this->chunkHash->getHash(), 'size' => $this->size, 'offset' => $this->offset )); } return $this->uploadPart; } /** * Checks if the size of the context is the same as the maximum size * * @return bool */ public function isFull() { return $this->size === $this->maxSize; } /** * Checks if the size of the context is 0 * * @return bool */ public function isEmpty() { return $this->size === 0; } } sdk-2.5.2/Aws/Glacier/Model/MultipartUpload/UploadPartGenerator.php000064411532700161006750000002120312272324172022325 0ustar 1) { // @codeCoverageIgnoreStart throw new RuntimeException('You cannot create a single upload that is larger than 4 GB.'); // @codeCoverageIgnoreEnd } return $generator->getUploadPart(1); } /** * @param EntityBodyInterface $body The upload body * @param int $partSize The size of parts to split the upload into. Default is the 4GB max * * @throws InvalidArgumentException when the part size is invalid (i.e. not a power of 2 of 1MB) * @throws InvalidArgumentException when the body is not seekable (must be able to rewind after calculating hashes) * @throws InvalidArgumentException when the archive size is less than one byte */ public function __construct(EntityBodyInterface $body, $partSize) { $this->partSize = $partSize; // Make sure the part size is valid $validPartSizes = array_map(function ($value) {return pow(2, $value) * Size::MB;}, range(0, 12)); if (!in_array($this->partSize, $validPartSizes)) { throw new InvalidArgumentException('The part size must be a megabyte multiplied by a power of 2 and no ' . 'greater than 4 gigabytes.'); } // Validate body if (!$body->isSeekable()) { throw new InvalidArgumentException('The upload body must be seekable.'); } $this->generateUploadParts($body); // Validate archive size if ($this->archiveSize < 1) { throw new InvalidArgumentException('The archive size must be at least 1 byte.'); } } /** * Returns a single upload part from the calculated uploads by part number. By default it returns the first, which * is useful behavior if there is only one upload. * * @param int $partNumber The numerical index of the upload * * @return UploadPart * @throws OutOfBoundsException if the index of the upload doesn't exist */ public function getUploadPart($partNumber) { $partNumber = (int) $partNumber; // Get the upload at the index if it exists if (isset($this->uploadParts[$partNumber - 1])) { return $this->uploadParts[$partNumber - 1]; } else { throw new OutOfBoundsException("An upload part with part number {$partNumber} at index did not exist."); } } /** * @return array */ public function getAllParts() { return $this->uploadParts; } /** * @return array */ public function getArchiveSize() { return $this->archiveSize; } /** * @return string */ public function getRootChecksum() { if (!$this->rootChecksum) { $this->rootChecksum = TreeHash::fromChecksums(array_map(function (UploadPart $part) { return $part->getChecksum(); }, $this->uploadParts))->getHash(); } return $this->rootChecksum; } /** * @return string */ public function getPartSize() { return $this->partSize; } /** * {@inheritdoc} */ public function serialize() { return serialize(array( 'uploadParts' => $this->uploadParts, 'archiveSize' => $this->archiveSize, 'partSize' => $this->partSize )); } /** * {@inheritdoc} */ public function unserialize($serialized) { // Unserialize data $data = unserialize($serialized); // Set properties foreach (array('uploadParts', 'archiveSize', 'partSize') as $property) { if (isset($data[$property])) { $this->{$property} = $data[$property]; } else { throw new RuntimeException(sprintf('Cannot unserialize the %s class. The %s property is missing.', __CLASS__, $property )); } } } /** * {@inheritdoc} */ public function getIterator() { return new \ArrayIterator($this->uploadParts); } /** * {@inheritdoc} */ public function count() { return count($this->uploadParts); } /** * Performs the work of reading the body stream, creating tree hashes, and creating UploadPartContext objects * * @param EntityBodyInterface $body The body to create parts from */ protected function generateUploadParts(EntityBodyInterface $body) { // Rewind the body stream $body->seek(0); // Initialize variables for tracking data for upload $uploadContext = new UploadPartContext($this->partSize, $body->ftell()); // Read the data from the streamed body in 1MB chunks while ($data = $body->read(min($this->partSize, Size::MB))) { // Add data to the hashes and size calculations $uploadContext->addData($data); // If the upload part is complete, generate an upload object and reset the currently tracked upload data if ($uploadContext->isFull()) { $this->updateTotals($uploadContext->generatePart()); $uploadContext = new UploadPartContext($this->partSize, $body->ftell()); } } // Handle any leftover data if (!$uploadContext->isEmpty()) { $this->updateTotals($uploadContext->generatePart()); } // Rewind the body stream $body->seek(0); } /** * Updated the upload helper running totals and tree hash with the data from a complete upload part * * @param UploadPart $part The newly completed upload part * * @throws OverflowException if the maximum number of allowed upload parts is exceeded */ protected function updateTotals(UploadPart $part) { // Throw an exception if there are more parts than total allowed if ($part->getPartNumber() > self::MAX_NUM_PARTS) { // @codeCoverageIgnoreStart throw new OverflowException('An archive must be uploaded in ' . self::MAX_NUM_PARTS . ' parts or less.'); // @codeCoverageIgnoreEnd } $this->uploadParts[] = $part; $this->archiveSize += $part->getSize(); } } sdk-2.5.2/Aws/Glacier/Resources/glacier-2012-06-01.php000064411532700161006750000016171212272324172016632 0ustar '2012-06-01', 'endpointPrefix' => 'glacier', 'serviceFullName' => 'Amazon Glacier', 'serviceType' => 'rest-json', 'signatureVersion' => 'v4', 'namespace' => 'Glacier', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.eu-west-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.ap-southeast-2.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.ap-northeast-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.cn-north-1.amazonaws.com.cn', ), ), 'operations' => array( 'AbortMultipartUpload' => array( 'httpMethod' => 'DELETE', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'uploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'CompleteMultipartUpload' => array( 'httpMethod' => 'POST', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ArchiveCreationOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'uploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'archiveSize' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-size', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'CreateVault' => array( 'httpMethod' => 'PUT', 'uri' => '/{accountId}/vaults/{vaultName}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateVaultOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), array( 'reason' => 'Returned if the request results in a vault or account limit being exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteArchive' => array( 'httpMethod' => 'DELETE', 'uri' => '/{accountId}/vaults/{vaultName}/archives/{archiveId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'archiveId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'DeleteVault' => array( 'httpMethod' => 'DELETE', 'uri' => '/{accountId}/vaults/{vaultName}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'DeleteVaultNotifications' => array( 'httpMethod' => 'DELETE', 'uri' => '/{accountId}/vaults/{vaultName}/notification-configuration', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'DescribeJob' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/jobs/{jobId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GlacierJobDescription', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'jobId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'DescribeVault' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DescribeVaultOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'GetJobOutput' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/jobs/{jobId}/output', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetJobOutputOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'jobId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'range' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Range', ), 'saveAs' => array( 'location' => 'response_body', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'GetVaultNotifications' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/notification-configuration', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetVaultNotificationsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'InitiateJob' => array( 'httpMethod' => 'POST', 'uri' => '/{accountId}/vaults/{vaultName}/jobs', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'InitiateJobOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Format' => array( 'type' => 'string', 'location' => 'json', ), 'Type' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveId' => array( 'type' => 'string', 'location' => 'json', ), 'Description' => array( 'type' => 'string', 'location' => 'json', ), 'SNSTopic' => array( 'type' => 'string', 'location' => 'json', ), 'RetrievalByteRange' => array( 'type' => 'string', 'location' => 'json', ), 'InventoryRetrievalParameters' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'StartDate' => array( 'type' => 'string', ), 'EndDate' => array( 'type' => 'string', ), 'Limit' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'InitiateMultipartUpload' => array( 'httpMethod' => 'POST', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'InitiateMultipartUploadOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'archiveDescription' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-description', ), 'partSize' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-part-size', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'ListJobs' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/jobs', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListJobsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'limit' => array( 'type' => 'string', 'location' => 'query', ), 'marker' => array( 'type' => 'string', 'location' => 'query', ), 'statuscode' => array( 'type' => 'string', 'location' => 'query', ), 'completed' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'ListMultipartUploads' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListMultipartUploadsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'limit' => array( 'type' => 'string', 'location' => 'query', ), 'marker' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'ListParts' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListPartsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'uploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'marker' => array( 'type' => 'string', 'location' => 'query', ), 'limit' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'ListVaults' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListVaultsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'marker' => array( 'type' => 'string', 'location' => 'query', ), 'limit' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'SetVaultNotifications' => array( 'httpMethod' => 'PUT', 'uri' => '/{accountId}/vaults/{vaultName}/notification-configuration', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'SNSTopic' => array( 'type' => 'string', 'location' => 'json', ), 'Events' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'string', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'UploadArchive' => array( 'httpMethod' => 'POST', 'uri' => '/{accountId}/vaults/{vaultName}/archives', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ArchiveCreationOutput', 'responseType' => 'model', 'parameters' => array( 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'archiveDescription' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-description', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), 'body' => array( 'type' => array( 'string', 'object', ), 'location' => 'body', ), 'ContentSHA256' => array( 'default' => true, ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if, when uploading an archive, Amazon Glacier times out while receiving the upload.', 'class' => 'RequestTimeoutException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'UploadMultipartPart' => array( 'httpMethod' => 'PUT', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UploadMultipartPartOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'uploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), 'range' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Range', ), 'body' => array( 'type' => array( 'string', 'object', ), 'location' => 'body', ), 'ContentSHA256' => array( 'default' => true, ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if, when uploading an archive, Amazon Glacier times out while receiving the upload.', 'class' => 'RequestTimeoutException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ArchiveCreationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'location' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Location', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), 'archiveId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-id', ), ), ), 'CreateVaultOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'location' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Location', ), ), ), 'GlacierJobDescription' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobId' => array( 'type' => 'string', 'location' => 'json', ), 'JobDescription' => array( 'type' => 'string', 'location' => 'json', ), 'Action' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveId' => array( 'type' => 'string', 'location' => 'json', ), 'VaultARN' => array( 'type' => 'string', 'location' => 'json', ), 'CreationDate' => array( 'type' => 'string', 'location' => 'json', ), 'Completed' => array( 'type' => 'boolean', 'location' => 'json', ), 'StatusCode' => array( 'type' => 'string', 'location' => 'json', ), 'StatusMessage' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveSizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'InventorySizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'SNSTopic' => array( 'type' => 'string', 'location' => 'json', ), 'CompletionDate' => array( 'type' => 'string', 'location' => 'json', ), 'SHA256TreeHash' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveSHA256TreeHash' => array( 'type' => 'string', 'location' => 'json', ), 'RetrievalByteRange' => array( 'type' => 'string', 'location' => 'json', ), 'InventoryRetrievalParameters' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'StartDate' => array( 'type' => 'string', ), 'EndDate' => array( 'type' => 'string', ), 'Limit' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), ), ), ), ), 'DescribeVaultOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VaultARN' => array( 'type' => 'string', 'location' => 'json', ), 'VaultName' => array( 'type' => 'string', 'location' => 'json', ), 'CreationDate' => array( 'type' => 'string', 'location' => 'json', ), 'LastInventoryDate' => array( 'type' => 'string', 'location' => 'json', ), 'NumberOfArchives' => array( 'type' => 'numeric', 'location' => 'json', ), 'SizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'GetJobOutputOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'body' => array( 'type' => 'string', 'instanceOf' => 'Guzzle\\Http\\EntityBody', 'location' => 'body', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), 'status' => array( 'type' => 'numeric', 'location' => 'statusCode', ), 'contentRange' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Range', ), 'acceptRanges' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Accept-Ranges', ), 'contentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'archiveDescription' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-description', ), ), ), 'GetVaultNotificationsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SNSTopic' => array( 'type' => 'string', 'location' => 'json', ), 'Events' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'string', 'type' => 'string', ), ), ), ), 'InitiateJobOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'location' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Location', ), 'jobId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-job-id', ), ), ), 'InitiateMultipartUploadOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'location' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Location', ), 'uploadId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-multipart-upload-id', ), ), ), 'ListJobsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'GlacierJobDescription', 'type' => 'object', 'properties' => array( 'JobId' => array( 'type' => 'string', ), 'JobDescription' => array( 'type' => 'string', ), 'Action' => array( 'type' => 'string', ), 'ArchiveId' => array( 'type' => 'string', ), 'VaultARN' => array( 'type' => 'string', ), 'CreationDate' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'boolean', ), 'StatusCode' => array( 'type' => 'string', ), 'StatusMessage' => array( 'type' => 'string', ), 'ArchiveSizeInBytes' => array( 'type' => 'numeric', ), 'InventorySizeInBytes' => array( 'type' => 'numeric', ), 'SNSTopic' => array( 'type' => 'string', ), 'CompletionDate' => array( 'type' => 'string', ), 'SHA256TreeHash' => array( 'type' => 'string', ), 'ArchiveSHA256TreeHash' => array( 'type' => 'string', ), 'RetrievalByteRange' => array( 'type' => 'string', ), 'InventoryRetrievalParameters' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'StartDate' => array( 'type' => 'string', ), 'EndDate' => array( 'type' => 'string', ), 'Limit' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListMultipartUploadsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UploadsList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'UploadListElement', 'type' => 'object', 'properties' => array( 'MultipartUploadId' => array( 'type' => 'string', ), 'VaultARN' => array( 'type' => 'string', ), 'ArchiveDescription' => array( 'type' => 'string', ), 'PartSizeInBytes' => array( 'type' => 'numeric', ), 'CreationDate' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListPartsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MultipartUploadId' => array( 'type' => 'string', 'location' => 'json', ), 'VaultARN' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveDescription' => array( 'type' => 'string', 'location' => 'json', ), 'PartSizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'CreationDate' => array( 'type' => 'string', 'location' => 'json', ), 'Parts' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PartListElement', 'type' => 'object', 'properties' => array( 'RangeInBytes' => array( 'type' => 'string', ), 'SHA256TreeHash' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListVaultsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VaultList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DescribeVaultOutput', 'type' => 'object', 'properties' => array( 'VaultARN' => array( 'type' => 'string', ), 'VaultName' => array( 'type' => 'string', ), 'CreationDate' => array( 'type' => 'string', ), 'LastInventoryDate' => array( 'type' => 'string', ), 'NumberOfArchives' => array( 'type' => 'numeric', ), 'SizeInBytes' => array( 'type' => 'numeric', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UploadMultipartPartOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 3, 'max_attempts' => 15, ), '__VaultState' => array( 'operation' => 'DescribeVault', ), 'VaultExists' => array( 'extends' => '__VaultState', 'success.type' => 'output', 'ignore_errors' => array( 'ResourceNotFoundException', ), ), 'VaultNotExists' => array( 'extends' => '__VaultState', 'success.type' => 'error', 'success.value' => 'ResourceNotFoundException', ), ), ); sdk-2.5.2/Aws/Iam/IamClient.php000064411532700161006750000002611112272324172013225 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/iam-%s.php' )) ->build(); } } sdk-2.5.2/Aws/Iam/Enum/AssignmentStatusType.php000064411532700161006750000000150312272324172016440 0ustar '2010-05-08', 'endpointPrefix' => 'iam', 'serviceFullName' => 'AWS Identity and Access Management', 'serviceAbbreviation' => 'IAM', 'serviceType' => 'query', 'globalEndpoint' => 'iam.amazonaws.com', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Iam', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.us-gov.amazonaws.com', ), ), 'operations' => array( 'AddRoleToInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddRoleToInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'AddUserToGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddUserToGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'ChangePassword' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ChangePassword', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'OldPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'NewPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the type of user for the transaction was incorrect.', 'class' => 'InvalidUserTypeException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), ), ), 'CreateAccessKey' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateAccessKeyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateAccessKey', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateAccountAlias' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateAccountAlias', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'AccountAlias' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 63, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateGroupResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'CreateInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateInstanceProfileResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateLoginProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateLoginProfileResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLoginProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'Password' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the provided password did not meet the requirements imposed by the account password policy.', 'class' => 'PasswordPolicyViolationException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'AssumeRolePolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), ), ), 'CreateSAMLProvider' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateSAMLProviderResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSAMLProvider', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SAMLMetadataDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1000, 'maxLength' => 10000000, ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'InvalidInputException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateUserResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'CreateVirtualMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateVirtualMFADeviceResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVirtualMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'VirtualMFADeviceName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), ), ), 'DeactivateMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeactivateMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'SerialNumber' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteAccessKey' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAccessKey', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'AccessKeyId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 16, 'maxLength' => 32, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteAccountAlias' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAccountAlias', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'AccountAlias' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 63, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteAccountPasswordPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAccountPasswordPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'DeleteGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteGroupPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteGroupPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteLoginProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLoginProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteRolePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRolePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteSAMLProvider' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSAMLProvider', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SAMLProviderArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'class' => 'InvalidInputException', ), ), ), 'DeleteServerCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteServerCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'ServerCertificateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteSigningCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSigningCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'CertificateId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 24, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), ), ), 'DeleteUserPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteUserPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteVirtualMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVirtualMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SerialNumber' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'EnableMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'SerialNumber' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), 'AuthenticationCode1' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), 'AuthenticationCode2' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), array( 'reason' => 'The request was rejected because the authentication code was not recognized. The error message describes the specific error.', 'class' => 'InvalidAuthenticationCodeException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetAccountPasswordPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetAccountPasswordPolicyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetAccountPasswordPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetAccountSummary' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetAccountSummaryResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetAccountSummary', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), ), ), 'GetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetGroupResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetGroupPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetGroupPolicyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetGroupPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetInstanceProfileResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetLoginProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetLoginProfileResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetLoginProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetRolePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetRolePolicyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetRolePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetSAMLProvider' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSAMLProviderResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSAMLProvider', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SAMLProviderArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'class' => 'InvalidInputException', ), ), ), 'GetServerCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetServerCertificateResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetServerCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'ServerCertificateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetUserResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetUserPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetUserPolicyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetUserPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListAccessKeys' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListAccessKeysResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListAccessKeys', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListAccountAliases' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListAccountAliasesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListAccountAliases', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListGroupPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListGroupPoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListGroupPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListGroupsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListGroupsForUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListGroupsForUserResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListGroupsForUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListInstanceProfiles' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListInstanceProfilesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListInstanceProfiles', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListInstanceProfilesForRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListInstanceProfilesForRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListInstanceProfilesForRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListMFADevices' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListMFADevicesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListMFADevices', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListRolePolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListRolePoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListRolePolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListRoles' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListRolesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListRoles', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListSAMLProviders' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListSAMLProvidersResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListSAMLProviders', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), ), ), 'ListServerCertificates' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListServerCertificatesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListServerCertificates', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListSigningCertificates' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListSigningCertificatesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListSigningCertificates', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListUserPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListUserPoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListUserPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListUsers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListUsersResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListUsers', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListVirtualMFADevices' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListVirtualMFADevicesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListVirtualMFADevices', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'AssignmentStatus' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'PutGroupPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutGroupPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'PutRolePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutRolePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'PutUserPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutUserPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'RemoveRoleFromInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemoveRoleFromInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'RemoveUserFromGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemoveUserFromGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'ResyncMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResyncMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'SerialNumber' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), 'AuthenticationCode1' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), 'AuthenticationCode2' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the authentication code was not recognized. The error message describes the specific error.', 'class' => 'InvalidAuthenticationCodeException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateAccessKey' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateAccessKey', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'AccessKeyId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 16, 'maxLength' => 32, ), 'Status' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateAccountPasswordPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateAccountPasswordPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'MinimumPasswordLength' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 6, 'maximum' => 128, ), 'RequireSymbols' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RequireNumbers' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RequireUppercaseCharacters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RequireLowercaseCharacters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AllowUsersToChangePassword' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateAssumeRolePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateAssumeRolePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'PolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'NewPath' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'NewGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateLoginProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateLoginProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'Password' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the provided password did not meet the requirements imposed by the account password policy.', 'class' => 'PasswordPolicyViolationException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateSAMLProvider' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateSAMLProviderResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateSAMLProvider', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SAMLMetadataDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1000, 'maxLength' => 10000000, ), 'SAMLProviderArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'class' => 'InvalidInputException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateServerCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateServerCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'ServerCertificateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'NewPath' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'NewServerCertificateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateSigningCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateSigningCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'CertificateId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 24, 'maxLength' => 128, ), 'Status' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'NewPath' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'NewUserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), ), ), 'UploadServerCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UploadServerCertificateResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UploadServerCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'ServerCertificateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'CertificateBody' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'PrivateKey' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'CertificateChain' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2097152, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because the certificate was malformed or expired. The error message describes the specific error.', 'class' => 'MalformedCertificateException', ), array( 'reason' => 'The request was rejected because the public key certificate and the private key do not match.', 'class' => 'KeyPairMismatchException', ), ), ), 'UploadSigningCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UploadSigningCertificateResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UploadSigningCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'CertificateBody' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because the certificate was malformed or expired. The error message describes the specific error.', 'class' => 'MalformedCertificateException', ), array( 'reason' => 'The request was rejected because the certificate is invalid.', 'class' => 'InvalidCertificateException', ), array( 'reason' => 'The request was rejected because the same certificate is associated to another user under the account.', 'class' => 'DuplicateCertificateException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreateAccessKeyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccessKey' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'AccessKeyId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'CreateGroupResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Group' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'CreateInstanceProfileResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceProfile' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'InstanceProfileName' => array( 'type' => 'string', ), 'InstanceProfileId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'Roles' => array( 'type' => 'array', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'CreateLoginProfileResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoginProfile' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'CreateRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Role' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), 'CreateSAMLProviderResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SAMLProviderArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'CreateUserResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'User' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'CreateVirtualMFADeviceResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VirtualMFADevice' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'SerialNumber' => array( 'type' => 'string', ), 'Base32StringSeed' => array( 'type' => 'string', ), 'QRCodePNG' => array( 'type' => 'string', ), 'User' => array( 'type' => 'object', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), 'EnableDate' => array( 'type' => 'string', ), ), ), ), ), 'GetAccountPasswordPolicyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PasswordPolicy' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'MinimumPasswordLength' => array( 'type' => 'numeric', ), 'RequireSymbols' => array( 'type' => 'boolean', ), 'RequireNumbers' => array( 'type' => 'boolean', ), 'RequireUppercaseCharacters' => array( 'type' => 'boolean', ), 'RequireLowercaseCharacters' => array( 'type' => 'boolean', ), 'AllowUsersToChangePassword' => array( 'type' => 'boolean', ), 'ExpirePasswords' => array( 'type' => 'boolean', ), 'MaxPasswordAge' => array( 'type' => 'numeric', ), ), ), ), ), 'GetAccountSummaryResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SummaryMap' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlMap' => array( 'Users', 'UsersQuota', 'Groups', 'GroupsQuota', 'ServerCertificates', 'ServerCertificatesQuota', 'UserPolicySizeQuota', 'GroupPolicySizeQuota', 'GroupsPerUserQuota', 'SigningCertificatesPerUserQuota', 'AccessKeysPerUserQuota', 'MFADevices', 'MFADevicesInUse', 'AccountMFAEnabled', ), ), 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'numeric', ), ), ), 'additionalProperties' => false, ), ), ), 'GetGroupResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Group' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), 'Users' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'User', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetGroupPolicyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GroupName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyDocument' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetInstanceProfileResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceProfile' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'InstanceProfileName' => array( 'type' => 'string', ), 'InstanceProfileId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'Roles' => array( 'type' => 'array', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'GetLoginProfileResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoginProfile' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'GetRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Role' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), 'GetRolePolicyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RoleName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyDocument' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetSAMLProviderResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SAMLMetadataDocument' => array( 'type' => 'string', 'location' => 'xml', ), 'CreateDate' => array( 'type' => 'string', 'location' => 'xml', ), 'ValidUntil' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetServerCertificateResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ServerCertificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'ServerCertificateMetadata' => array( 'type' => 'object', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'ServerCertificateName' => array( 'type' => 'string', ), 'ServerCertificateId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), 'CertificateBody' => array( 'type' => 'string', ), 'CertificateChain' => array( 'type' => 'string', ), ), ), ), ), 'GetUserResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'User' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'GetUserPolicyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UserName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyDocument' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListAccessKeysResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccessKeyMetadata' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AccessKeyMetadata', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'AccessKeyId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListAccountAliasesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccountAliases' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'accountAliasType', 'type' => 'string', 'sentAs' => 'member', ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListGroupPoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyNames' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'policyNameType', 'type' => 'string', 'sentAs' => 'member', ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListGroupsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Groups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Group', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListGroupsForUserResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Groups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Group', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListInstanceProfilesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceProfiles' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InstanceProfile', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'InstanceProfileName' => array( 'type' => 'string', ), 'InstanceProfileId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'Roles' => array( 'type' => 'array', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListInstanceProfilesForRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceProfiles' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InstanceProfile', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'InstanceProfileName' => array( 'type' => 'string', ), 'InstanceProfileId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'Roles' => array( 'type' => 'array', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListMFADevicesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MFADevices' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MFADevice', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'SerialNumber' => array( 'type' => 'string', ), 'EnableDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListRolePoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyNames' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'policyNameType', 'type' => 'string', 'sentAs' => 'member', ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListRolesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Roles' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListSAMLProvidersResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SAMLProviderList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SAMLProviderListEntry', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'ValidUntil' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), ), 'ListServerCertificatesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ServerCertificateMetadataList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ServerCertificateMetadata', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'ServerCertificateName' => array( 'type' => 'string', ), 'ServerCertificateId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListSigningCertificatesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Certificates' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SigningCertificate', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'CertificateId' => array( 'type' => 'string', ), 'CertificateBody' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListUserPoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyNames' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'policyNameType', 'type' => 'string', 'sentAs' => 'member', ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListUsersResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Users' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'User', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListVirtualMFADevicesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VirtualMFADevices' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'VirtualMFADevice', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SerialNumber' => array( 'type' => 'string', ), 'Base32StringSeed' => array( 'type' => 'string', ), 'QRCodePNG' => array( 'type' => 'string', ), 'User' => array( 'type' => 'object', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), 'EnableDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'UpdateSAMLProviderResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SAMLProviderArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'UploadServerCertificateResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ServerCertificateMetadata' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'ServerCertificateName' => array( 'type' => 'string', ), 'ServerCertificateId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), ), ), 'UploadSigningCertificateResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Certificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'CertificateId' => array( 'type' => 'string', ), 'CertificateBody' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'GetGroup' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Users', ), 'ListAccessKeys' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'AccessKeyMetadata', ), 'ListAccountAliases' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'AccountAliases', ), 'ListGroupPolicies' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'PolicyNames', ), 'ListGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Groups', ), 'ListGroupsForUser' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Groups', ), 'ListInstanceProfiles' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'InstanceProfiles', ), 'ListInstanceProfilesForRole' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'InstanceProfiles', ), 'ListMFADevices' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'MFADevices', ), 'ListRolePolicies' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'PolicyNames', ), 'ListRoles' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Roles', ), 'ListSAMLProviders' => array( 'result_key' => 'SAMLProviderList', ), 'ListServerCertificates' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'ServerCertificateMetadataList', ), 'ListSigningCertificates' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Certificates', ), 'ListUserPolicies' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'PolicyNames', ), 'ListUsers' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Users', ), 'ListVirtualMFADevices' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'VirtualMFADevices', ), ), ), ); sdk-2.5.2/Aws/ImportExport/ImportExportClient.php000064411532700161006750000000544012272324172017143 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/importexport-%s.php' )) ->build(); // If the Symfony YAML component is installed, add a listener that will convert arrays to proper YAML in when // specifying the "Manifest" parameter of the "CreateJob" operation if (class_exists('Symfony\Component\Yaml\Yaml')) { $client->addSubscriber(new JobManifestListener()); } return $client; } } sdk-2.5.2/Aws/ImportExport/JobManifestListener.php000064411532700161006750000000330212272324172017232 0ustar array('onCommandBeforePrepare')); } /** * An event handler for assisting with formatting the Manifest parameter of CreateJob operation into YAML * * @param Event $event The event being handled */ public function onCommandBeforePrepare(Event $event) { /** @var $command \Guzzle\Service\Command\AbstractCommand */ $command = $event['command']; if ($command->getName() === 'CreateJob') { $manifest = $command->get('Manifest'); if (!is_string($manifest) && class_exists('Symfony\Component\Yaml\Yaml')) { $command->set('Manifest', \Symfony\Component\Yaml\Yaml::dump($manifest)); } } } } sdk-2.5.2/Aws/ImportExport/Enum/JobType.php000064411532700161006750000000141712272324172015610 0ustar nextToken = null; if ($result->get($this->get('more_key'))) { $jobs = $result->get($this->get('result_key')) ?: array(); $numJobs = count($jobs); $this->nextToken = $numJobs ? $jobs[$numJobs - 1]['JobId'] : null; } } } sdk-2.5.2/Aws/ImportExport/Resources/importexport-2010-06-01.php000064411532700161006750000005477012272324172021111 0ustar '2010-06-01', 'endpointPrefix' => 'importexport', 'serviceFullName' => 'AWS Import/Export', 'serviceType' => 'query', 'globalEndpoint' => 'importexport.amazonaws.com', 'resultWrapped' => true, 'signatureVersion' => 'v2', 'namespace' => 'ImportExport', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), ), 'operations' => array( 'CancelJob' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CancelJobOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelJob', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'JobId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', 'class' => 'InvalidJobIdException', ), array( 'reason' => 'Indicates that the specified job has expired out of the system.', 'class' => 'ExpiredJobIdException', ), array( 'reason' => 'The specified job ID has been canceled and is no longer valid.', 'class' => 'CanceledJobIdException', ), array( 'reason' => 'AWS Import/Export cannot cancel the job', 'class' => 'UnableToCancelJobIdException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), ), ), 'CreateJob' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateJobOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateJob', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'JobType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Manifest' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ManifestAddendum' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ValidateOnly' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameters was missing from the request.', 'class' => 'MissingParameterException', ), array( 'reason' => 'One or more parameters had an invalid value.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'One or more parameters had an invalid value.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), array( 'reason' => 'The address specified in the manifest is invalid.', 'class' => 'InvalidAddressException', ), array( 'reason' => 'One or more manifest fields was invalid. Please correct and resubmit.', 'class' => 'InvalidManifestFieldException', ), array( 'reason' => 'One or more required fields were missing from the manifest file. Please correct and resubmit.', 'class' => 'MissingManifestFieldException', ), array( 'reason' => 'The specified bucket does not exist. Create the specified bucket or change the manifest\'s bucket, exportBucket, or logBucket field to a bucket that the account, as specified by the manifest\'s Access Key ID, has write permissions to.', 'class' => 'NoSuchBucketException', ), array( 'reason' => 'One or more required customs parameters was missing from the manifest.', 'class' => 'MissingCustomsException', ), array( 'reason' => 'One or more customs parameters was invalid. Please correct and resubmit.', 'class' => 'InvalidCustomsException', ), array( 'reason' => 'File system specified in export manifest is invalid.', 'class' => 'InvalidFileSystemException', ), array( 'reason' => 'Your manifest file contained buckets from multiple regions. A job is restricted to buckets from one region. Please correct and resubmit.', 'class' => 'MultipleRegionsException', ), array( 'reason' => 'The account specified does not have the appropriate bucket permissions.', 'class' => 'BucketPermissionException', ), array( 'reason' => 'Your manifest is not well-formed.', 'class' => 'MalformedManifestException', ), ), ), 'GetStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetStatusOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'JobId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', 'class' => 'InvalidJobIdException', ), array( 'reason' => 'Indicates that the specified job has expired out of the system.', 'class' => 'ExpiredJobIdException', ), array( 'reason' => 'The specified job ID has been canceled and is no longer valid.', 'class' => 'CanceledJobIdException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), ), ), 'ListJobs' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListJobsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListJobs', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'MaxJobs' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more parameters had an invalid value.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), ), ), 'UpdateJob' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateJobOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateJob', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'JobId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Manifest' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'JobType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ValidateOnly' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameters was missing from the request.', 'class' => 'MissingParameterException', ), array( 'reason' => 'One or more parameters had an invalid value.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), array( 'reason' => 'The address specified in the manifest is invalid.', 'class' => 'InvalidAddressException', ), array( 'reason' => 'One or more manifest fields was invalid. Please correct and resubmit.', 'class' => 'InvalidManifestFieldException', ), array( 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', 'class' => 'InvalidJobIdException', ), array( 'reason' => 'One or more required fields were missing from the manifest file. Please correct and resubmit.', 'class' => 'MissingManifestFieldException', ), array( 'reason' => 'The specified bucket does not exist. Create the specified bucket or change the manifest\'s bucket, exportBucket, or logBucket field to a bucket that the account, as specified by the manifest\'s Access Key ID, has write permissions to.', 'class' => 'NoSuchBucketException', ), array( 'reason' => 'Indicates that the specified job has expired out of the system.', 'class' => 'ExpiredJobIdException', ), array( 'reason' => 'The specified job ID has been canceled and is no longer valid.', 'class' => 'CanceledJobIdException', ), array( 'reason' => 'One or more required customs parameters was missing from the manifest.', 'class' => 'MissingCustomsException', ), array( 'reason' => 'One or more customs parameters was invalid. Please correct and resubmit.', 'class' => 'InvalidCustomsException', ), array( 'reason' => 'File system specified in export manifest is invalid.', 'class' => 'InvalidFileSystemException', ), array( 'reason' => 'Your manifest file contained buckets from multiple regions. A job is restricted to buckets from one region. Please correct and resubmit.', 'class' => 'MultipleRegionsException', ), array( 'reason' => 'The account specified does not have the appropriate bucket permissions.', 'class' => 'BucketPermissionException', ), array( 'reason' => 'Your manifest is not well-formed.', 'class' => 'MalformedManifestException', ), ), ), ), 'models' => array( 'CancelJobOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Success' => array( 'type' => 'boolean', 'location' => 'xml', ), ), ), 'CreateJobOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobId' => array( 'type' => 'string', 'location' => 'xml', ), 'JobType' => array( 'type' => 'string', 'location' => 'xml', ), 'AwsShippingAddress' => array( 'type' => 'string', 'location' => 'xml', ), 'Signature' => array( 'type' => 'string', 'location' => 'xml', ), 'SignatureFileContents' => array( 'type' => 'string', 'location' => 'xml', ), 'WarningMessage' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetStatusOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobId' => array( 'type' => 'string', 'location' => 'xml', ), 'JobType' => array( 'type' => 'string', 'location' => 'xml', ), 'AwsShippingAddress' => array( 'type' => 'string', 'location' => 'xml', ), 'LocationCode' => array( 'type' => 'string', 'location' => 'xml', ), 'LocationMessage' => array( 'type' => 'string', 'location' => 'xml', ), 'ProgressCode' => array( 'type' => 'string', 'location' => 'xml', ), 'ProgressMessage' => array( 'type' => 'string', 'location' => 'xml', ), 'Carrier' => array( 'type' => 'string', 'location' => 'xml', ), 'TrackingNumber' => array( 'type' => 'string', 'location' => 'xml', ), 'LogBucket' => array( 'type' => 'string', 'location' => 'xml', ), 'LogKey' => array( 'type' => 'string', 'location' => 'xml', ), 'ErrorCount' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Signature' => array( 'type' => 'string', 'location' => 'xml', ), 'SignatureFileContents' => array( 'type' => 'string', 'location' => 'xml', ), 'CurrentManifest' => array( 'type' => 'string', 'location' => 'xml', ), 'CreationDate' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListJobsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Jobs' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Job', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'JobId' => array( 'type' => 'string', ), 'CreationDate' => array( 'type' => 'string', ), 'IsCanceled' => array( 'type' => 'boolean', ), 'JobType' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), ), ), 'UpdateJobOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Success' => array( 'type' => 'boolean', 'location' => 'xml', ), 'WarningMessage' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'ListJobs' => array( 'token_param' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxJobs', 'result_key' => 'Jobs', ), ), ), ); sdk-2.5.2/Aws/Kinesis/KinesisClient.php000064411532700161006750000000610112272324172015020 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/kinesis-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser) ->build(); } public function __call($method, $args) { // Overrides the parent behavior to make sure that the GetShardIterator operation works correctly if ($method === 'getShardIterator') { $params = isset($args[0]) ? $args[0] : array(); return $this->getCommand($method, $params)->getResult(); } else { return parent::__call($method, $args); } } } sdk-2.5.2/Aws/Kinesis/Enum/ShardIteratorType.php000064411532700161006750000000163212272324172016601 0ustar '2013-12-02', 'endpointPrefix' => 'kinesis', 'serviceFullName' => 'Amazon Kinesis', 'serviceAbbreviation' => 'Kinesis', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'Kinesis_20131202.', 'signatureVersion' => 'v4', 'namespace' => 'Kinesis', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'kinesis.us-east-1.amazonaws.com', ), ), 'operations' => array( 'CreateStream' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.CreateStream', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'class' => 'ResourceInUseException', ), array( 'class' => 'LimitExceededException', ), array( 'class' => 'InvalidArgumentException', ), ), ), 'DeleteStream' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.DeleteStream', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'LimitExceededException', ), ), ), 'DescribeStream' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStreamOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.DescribeStream', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 10000, ), 'ExclusiveStartShardId' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'LimitExceededException', ), ), ), 'GetRecords' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetRecordsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.GetRecords', ), 'ShardIterator' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 512, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 10000, ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'ProvisionedThroughputExceededException', ), array( 'class' => 'ExpiredIteratorException', ), ), ), 'GetShardIterator' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetShardIteratorOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.GetShardIterator', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardIteratorType' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'StartingSequenceNumber' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'ProvisionedThroughputExceededException', ), ), ), 'ListStreams' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListStreamsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.ListStreams', ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 10000, ), 'ExclusiveStartStreamName' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'LimitExceededException', ), ), ), 'MergeShards' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.MergeShards', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardToMerge' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'AdjacentShardToMerge' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'ResourceInUseException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'LimitExceededException', ), ), ), 'PutRecord' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PutRecordOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.PutRecord', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'Data' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'filters' => array( 'base64_encode', ), ), 'PartitionKey' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'ExplicitHashKey' => array( 'type' => 'string', 'location' => 'json', ), 'SequenceNumberForOrdering' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'ProvisionedThroughputExceededException', ), ), ), 'SplitShard' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.SplitShard', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardToSplit' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'NewStartingHashKey' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'ResourceInUseException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'LimitExceededException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeStreamOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StreamDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'StreamName' => array( 'type' => 'string', ), 'StreamARN' => array( 'type' => 'string', ), 'StreamStatus' => array( 'type' => 'string', ), 'Shards' => array( 'type' => 'array', 'items' => array( 'name' => 'Shard', 'type' => 'object', 'properties' => array( 'ShardId' => array( 'type' => 'string', ), 'ParentShardId' => array( 'type' => 'string', ), 'AdjacentParentShardId' => array( 'type' => 'string', ), 'HashKeyRange' => array( 'type' => 'object', 'properties' => array( 'StartingHashKey' => array( 'type' => 'string', ), 'EndingHashKey' => array( 'type' => 'string', ), ), ), 'SequenceNumberRange' => array( 'type' => 'object', 'properties' => array( 'StartingSequenceNumber' => array( 'type' => 'string', ), 'EndingSequenceNumber' => array( 'type' => 'string', ), ), ), ), ), ), 'HasMoreShards' => array( 'type' => 'boolean', ), ), ), ), ), 'GetRecordsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Records' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Record', 'type' => 'object', 'properties' => array( 'SequenceNumber' => array( 'type' => 'string', ), 'Data' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'PartitionKey' => array( 'type' => 'string', ), ), ), ), 'NextShardIterator' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'GetShardIteratorOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ShardIterator' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListStreamsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StreamNames' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StreamName', 'type' => 'string', ), ), 'HasMoreStreams' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'PutRecordOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ShardId' => array( 'type' => 'string', 'location' => 'json', ), 'SequenceNumber' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), ); sdk-2.5.2/Aws/OpsWorks/OpsWorksClient.php000064411532700161006750000002260412272324172015372 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/opsworks-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } sdk-2.5.2/Aws/OpsWorks/Enum/AppType.php000064411532700161006750000000156112272324172014731 0ustar '2013-02-18', 'endpointPrefix' => 'opsworks', 'serviceFullName' => 'AWS OpsWorks', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'OpsWorks_20130218.', 'signatureVersion' => 'v4', 'namespace' => 'OpsWorks', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'opsworks.us-east-1.amazonaws.com', ), ), 'operations' => array( 'AssignVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.AssignVolume', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'AssociateElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.AssociateElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'AttachElasticLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.AttachElasticLoadBalancer', ), 'ElasticLoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CloneStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CloneStackResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CloneStack', ), 'SourceStackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'Region' => array( 'type' => 'string', 'location' => 'json', ), 'VpcId' => array( 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'StackAttributesKeys', ), ), ), 'ServiceRoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'DefaultInstanceProfileArn' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultOs' => array( 'type' => 'string', 'location' => 'json', ), 'HostnameTheme' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultAvailabilityZone' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultSubnetId' => array( 'type' => 'string', 'location' => 'json', ), 'CustomJson' => array( 'type' => 'string', 'location' => 'json', ), 'ConfigurationManager' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'UseCustomCookbooks' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomCookbooksSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'DefaultSshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'ClonePermissions' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CloneAppIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'DefaultRootDeviceType' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateApp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateAppResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateApp', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Shortname' => array( 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Description' => array( 'type' => 'string', 'location' => 'json', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AppSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'Domains' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'EnableSsl' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'SslConfiguration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Certificate' => array( 'required' => true, 'type' => 'string', ), 'PrivateKey' => array( 'required' => true, 'type' => 'string', ), 'Chain' => array( 'type' => 'string', ), ), ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'AppAttributesKeys', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateDeployment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateDeploymentResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateDeployment', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AppId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Command' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'Args' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'array', 'data' => array( 'shape_name' => 'String', ), 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), 'Comment' => array( 'type' => 'string', 'location' => 'json', ), 'CustomJson' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateInstanceResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateInstance', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'LayerIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'InstanceType' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AutoScalingType' => array( 'type' => 'string', 'location' => 'json', ), 'Hostname' => array( 'type' => 'string', 'location' => 'json', ), 'Os' => array( 'type' => 'string', 'location' => 'json', ), 'AmiId' => array( 'type' => 'string', 'location' => 'json', ), 'SshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'json', ), 'SubnetId' => array( 'type' => 'string', 'location' => 'json', ), 'Architecture' => array( 'type' => 'string', 'location' => 'json', ), 'RootDeviceType' => array( 'type' => 'string', 'location' => 'json', ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateLayer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateLayerResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateLayer', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Shortname' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'LayerAttributesKeys', ), ), ), 'CustomInstanceProfileArn' => array( 'type' => 'string', 'location' => 'json', ), 'CustomSecurityGroupIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Packages' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'VolumeConfigurations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeConfiguration', 'type' => 'object', 'properties' => array( 'MountPoint' => array( 'required' => true, 'type' => 'string', ), 'RaidLevel' => array( 'type' => 'numeric', ), 'NumberOfDisks' => array( 'required' => true, 'type' => 'numeric', ), 'Size' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), 'EnableAutoHealing' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AutoAssignElasticIps' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AutoAssignPublicIps' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomRecipes' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Setup' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Configure' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Deploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Undeploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Shutdown' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateStackResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateStack', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Region' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'VpcId' => array( 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'StackAttributesKeys', ), ), ), 'ServiceRoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'DefaultInstanceProfileArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'DefaultOs' => array( 'type' => 'string', 'location' => 'json', ), 'HostnameTheme' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultAvailabilityZone' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultSubnetId' => array( 'type' => 'string', 'location' => 'json', ), 'CustomJson' => array( 'type' => 'string', 'location' => 'json', ), 'ConfigurationManager' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'UseCustomCookbooks' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomCookbooksSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'DefaultSshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultRootDeviceType' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), ), ), 'CreateUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateUserProfileResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateUserProfile', ), 'IamUserArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'SshUsername' => array( 'type' => 'string', 'location' => 'json', ), 'SshPublicKey' => array( 'type' => 'string', 'location' => 'json', ), 'AllowSelfManagement' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), ), ), 'DeleteApp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteApp', ), 'AppId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'DeleteElasticIp' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'DeleteVolumes' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteLayer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteLayer', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteStack', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteUserProfile', ), 'IamUserArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeregisterElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeregisterElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeregisterVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeregisterVolume', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeApps' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeAppsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeApps', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'AppIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeCommands' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCommandsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeCommands', ), 'DeploymentId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'CommandIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeDeployments' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeDeploymentsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeDeployments', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'AppId' => array( 'type' => 'string', 'location' => 'json', ), 'DeploymentIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeElasticIps' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeElasticIpsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeElasticIps', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'Ips' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeElasticLoadBalancers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeElasticLoadBalancersResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeElasticLoadBalancers', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'LayerIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeInstances', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'LayerId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeLayers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeLayersResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeLayers', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'LayerIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeLoadBasedAutoScaling' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeLoadBasedAutoScalingResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeLoadBasedAutoScaling', ), 'LayerIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeMyUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeMyUserProfileResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeMyUserProfile', ), ), ), 'DescribePermissions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribePermissionsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribePermissions', ), 'IamUserArn' => array( 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeRaidArrays' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeRaidArraysResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeRaidArrays', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'RaidArrayIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeServiceErrors' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeServiceErrorsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeServiceErrors', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'ServiceErrorIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeStackSummary' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStackSummaryResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeStackSummary', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeStacks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStacksResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeStacks', ), 'StackIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeTimeBasedAutoScaling' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTimeBasedAutoScalingResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeTimeBasedAutoScaling', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeUserProfiles' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeUserProfilesResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeUserProfiles', ), 'IamUserArns' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeVolumesResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeVolumes', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'RaidArrayId' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DetachElasticLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DetachElasticLoadBalancer', ), 'ElasticLoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DisassociateElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DisassociateElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'GetHostnameSuggestion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetHostnameSuggestionResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.GetHostnameSuggestion', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'RebootInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.RebootInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'RegisterElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RegisterElasticIpResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.RegisterElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'RegisterVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RegisterVolumeResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.RegisterVolume', ), 'Ec2VolumeId' => array( 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'SetLoadBasedAutoScaling' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.SetLoadBasedAutoScaling', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Enable' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'UpScaling' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'InstanceCount' => array( 'type' => 'numeric', ), 'ThresholdsWaitTime' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 100, ), 'IgnoreMetricsTime' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 100, ), 'CpuThreshold' => array( 'type' => 'numeric', ), 'MemoryThreshold' => array( 'type' => 'numeric', ), 'LoadThreshold' => array( 'type' => 'numeric', ), ), ), 'DownScaling' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'InstanceCount' => array( 'type' => 'numeric', ), 'ThresholdsWaitTime' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 100, ), 'IgnoreMetricsTime' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 100, ), 'CpuThreshold' => array( 'type' => 'numeric', ), 'MemoryThreshold' => array( 'type' => 'numeric', ), 'LoadThreshold' => array( 'type' => 'numeric', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'SetPermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.SetPermission', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'IamUserArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AllowSsh' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AllowSudo' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'Level' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'SetTimeBasedAutoScaling' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.SetTimeBasedAutoScaling', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AutoScalingSchedule' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Monday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Tuesday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Wednesday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Thursday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Friday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Saturday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Sunday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'StartInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.StartInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'StartStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.StartStack', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'StopInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.StopInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'StopStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.StopStack', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UnassignVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UnassignVolume', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateApp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateApp', ), 'AppId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'Description' => array( 'type' => 'string', 'location' => 'json', ), 'Type' => array( 'type' => 'string', 'location' => 'json', ), 'AppSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'Domains' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'EnableSsl' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'SslConfiguration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Certificate' => array( 'required' => true, 'type' => 'string', ), 'PrivateKey' => array( 'required' => true, 'type' => 'string', ), 'Chain' => array( 'type' => 'string', ), ), ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'AppAttributesKeys', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'LayerIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'InstanceType' => array( 'type' => 'string', 'location' => 'json', ), 'AutoScalingType' => array( 'type' => 'string', 'location' => 'json', ), 'Hostname' => array( 'type' => 'string', 'location' => 'json', ), 'Os' => array( 'type' => 'string', 'location' => 'json', ), 'AmiId' => array( 'type' => 'string', 'location' => 'json', ), 'SshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'Architecture' => array( 'type' => 'string', 'location' => 'json', ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateLayer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateLayer', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'Shortname' => array( 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'LayerAttributesKeys', ), ), ), 'CustomInstanceProfileArn' => array( 'type' => 'string', 'location' => 'json', ), 'CustomSecurityGroupIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Packages' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'VolumeConfigurations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeConfiguration', 'type' => 'object', 'properties' => array( 'MountPoint' => array( 'required' => true, 'type' => 'string', ), 'RaidLevel' => array( 'type' => 'numeric', ), 'NumberOfDisks' => array( 'required' => true, 'type' => 'numeric', ), 'Size' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), 'EnableAutoHealing' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AutoAssignElasticIps' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AutoAssignPublicIps' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomRecipes' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Setup' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Configure' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Deploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Undeploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Shutdown' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateMyUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateMyUserProfile', ), 'SshPublicKey' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), ), ), 'UpdateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateStack', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'StackAttributesKeys', ), ), ), 'ServiceRoleArn' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultInstanceProfileArn' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultOs' => array( 'type' => 'string', 'location' => 'json', ), 'HostnameTheme' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultAvailabilityZone' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultSubnetId' => array( 'type' => 'string', 'location' => 'json', ), 'CustomJson' => array( 'type' => 'string', 'location' => 'json', ), 'ConfigurationManager' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'UseCustomCookbooks' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomCookbooksSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'DefaultSshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultRootDeviceType' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateUserProfile', ), 'IamUserArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'SshUsername' => array( 'type' => 'string', 'location' => 'json', ), 'SshPublicKey' => array( 'type' => 'string', 'location' => 'json', ), 'AllowSelfManagement' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateVolume', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'MountPoint' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CloneStackResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateAppResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AppId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateDeploymentResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DeploymentId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateInstanceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateLayerResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LayerId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateStackResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateUserProfileResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IamUserArn' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeAppsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Apps' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'App', 'type' => 'object', 'properties' => array( 'AppId' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'Shortname' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'AppSource' => array( 'type' => 'object', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'Domains' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'EnableSsl' => array( 'type' => 'boolean', ), 'SslConfiguration' => array( 'type' => 'object', 'properties' => array( 'Certificate' => array( 'type' => 'string', ), 'PrivateKey' => array( 'type' => 'string', ), 'Chain' => array( 'type' => 'string', ), ), ), 'Attributes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'CreatedAt' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeCommandsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Commands' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Command', 'type' => 'object', 'properties' => array( 'CommandId' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), 'DeploymentId' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), 'AcknowledgedAt' => array( 'type' => 'string', ), 'CompletedAt' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'ExitCode' => array( 'type' => 'numeric', ), 'LogUrl' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeDeploymentsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Deployments' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Deployment', 'type' => 'object', 'properties' => array( 'DeploymentId' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'AppId' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), 'CompletedAt' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'IamUserArn' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), 'Command' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), 'Status' => array( 'type' => 'string', ), 'CustomJson' => array( 'type' => 'string', ), 'InstanceIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeElasticIpsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ElasticIps' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ElasticIp', 'type' => 'object', 'properties' => array( 'Ip' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Domain' => array( 'type' => 'string', ), 'Region' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeElasticLoadBalancersResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ElasticLoadBalancers' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ElasticLoadBalancer', 'type' => 'object', 'properties' => array( 'ElasticLoadBalancerName' => array( 'type' => 'string', ), 'Region' => array( 'type' => 'string', ), 'DnsName' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'LayerId' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'SubnetIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Ec2InstanceIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Instances' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'Ec2InstanceId' => array( 'type' => 'string', ), 'Hostname' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'LayerIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'InstanceType' => array( 'type' => 'string', ), 'InstanceProfileArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Os' => array( 'type' => 'string', ), 'AmiId' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'SubnetId' => array( 'type' => 'string', ), 'PublicDns' => array( 'type' => 'string', ), 'PrivateDns' => array( 'type' => 'string', ), 'PublicIp' => array( 'type' => 'string', ), 'PrivateIp' => array( 'type' => 'string', ), 'ElasticIp' => array( 'type' => 'string', ), 'AutoScalingType' => array( 'type' => 'string', ), 'SshKeyName' => array( 'type' => 'string', ), 'SshHostRsaKeyFingerprint' => array( 'type' => 'string', ), 'SshHostDsaKeyFingerprint' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), 'LastServiceErrorId' => array( 'type' => 'string', ), 'Architecture' => array( 'type' => 'string', ), 'RootDeviceType' => array( 'type' => 'string', ), 'RootDeviceVolumeId' => array( 'type' => 'string', ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', ), ), ), ), ), ), 'DescribeLayersResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Layers' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Layer', 'type' => 'object', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'LayerId' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Shortname' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'CustomInstanceProfileArn' => array( 'type' => 'string', ), 'CustomSecurityGroupIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'DefaultSecurityGroupNames' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Packages' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'VolumeConfigurations' => array( 'type' => 'array', 'items' => array( 'name' => 'VolumeConfiguration', 'type' => 'object', 'properties' => array( 'MountPoint' => array( 'type' => 'string', ), 'RaidLevel' => array( 'type' => 'numeric', ), 'NumberOfDisks' => array( 'type' => 'numeric', ), 'Size' => array( 'type' => 'numeric', ), ), ), ), 'EnableAutoHealing' => array( 'type' => 'boolean', ), 'AutoAssignElasticIps' => array( 'type' => 'boolean', ), 'AutoAssignPublicIps' => array( 'type' => 'boolean', ), 'DefaultRecipes' => array( 'type' => 'object', 'properties' => array( 'Setup' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Configure' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Deploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Undeploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Shutdown' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'CustomRecipes' => array( 'type' => 'object', 'properties' => array( 'Setup' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Configure' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Deploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Undeploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Shutdown' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'CreatedAt' => array( 'type' => 'string', ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', ), ), ), ), ), ), 'DescribeLoadBasedAutoScalingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoadBasedAutoScalingConfigurations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'LoadBasedAutoScalingConfiguration', 'type' => 'object', 'properties' => array( 'LayerId' => array( 'type' => 'string', ), 'Enable' => array( 'type' => 'boolean', ), 'UpScaling' => array( 'type' => 'object', 'properties' => array( 'InstanceCount' => array( 'type' => 'numeric', ), 'ThresholdsWaitTime' => array( 'type' => 'numeric', ), 'IgnoreMetricsTime' => array( 'type' => 'numeric', ), 'CpuThreshold' => array( 'type' => 'numeric', ), 'MemoryThreshold' => array( 'type' => 'numeric', ), 'LoadThreshold' => array( 'type' => 'numeric', ), ), ), 'DownScaling' => array( 'type' => 'object', 'properties' => array( 'InstanceCount' => array( 'type' => 'numeric', ), 'ThresholdsWaitTime' => array( 'type' => 'numeric', ), 'IgnoreMetricsTime' => array( 'type' => 'numeric', ), 'CpuThreshold' => array( 'type' => 'numeric', ), 'MemoryThreshold' => array( 'type' => 'numeric', ), 'LoadThreshold' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'DescribeMyUserProfileResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UserProfile' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'IamUserArn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'SshUsername' => array( 'type' => 'string', ), 'SshPublicKey' => array( 'type' => 'string', ), ), ), ), ), 'DescribePermissionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Permissions' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'IamUserArn' => array( 'type' => 'string', ), 'AllowSsh' => array( 'type' => 'boolean', ), 'AllowSudo' => array( 'type' => 'boolean', ), 'Level' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeRaidArraysResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RaidArrays' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'RaidArray', 'type' => 'object', 'properties' => array( 'RaidArrayId' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'RaidLevel' => array( 'type' => 'numeric', ), 'NumberOfDisks' => array( 'type' => 'numeric', ), 'Size' => array( 'type' => 'numeric', ), 'Device' => array( 'type' => 'string', ), 'MountPoint' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeServiceErrorsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ServiceErrors' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ServiceError', 'type' => 'object', 'properties' => array( 'ServiceErrorId' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeStackSummaryResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackSummary' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'LayersCount' => array( 'type' => 'numeric', ), 'AppsCount' => array( 'type' => 'numeric', ), 'InstancesCount' => array( 'type' => 'object', 'properties' => array( 'Booting' => array( 'type' => 'numeric', ), 'ConnectionLost' => array( 'type' => 'numeric', ), 'Pending' => array( 'type' => 'numeric', ), 'Rebooting' => array( 'type' => 'numeric', ), 'Requested' => array( 'type' => 'numeric', ), 'RunningSetup' => array( 'type' => 'numeric', ), 'SetupFailed' => array( 'type' => 'numeric', ), 'ShuttingDown' => array( 'type' => 'numeric', ), 'StartFailed' => array( 'type' => 'numeric', ), 'Stopped' => array( 'type' => 'numeric', ), 'Terminated' => array( 'type' => 'numeric', ), 'Terminating' => array( 'type' => 'numeric', ), ), ), ), ), ), ), 'DescribeStacksResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stacks' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Stack', 'type' => 'object', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Region' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'ServiceRoleArn' => array( 'type' => 'string', ), 'DefaultInstanceProfileArn' => array( 'type' => 'string', ), 'DefaultOs' => array( 'type' => 'string', ), 'HostnameTheme' => array( 'type' => 'string', ), 'DefaultAvailabilityZone' => array( 'type' => 'string', ), 'DefaultSubnetId' => array( 'type' => 'string', ), 'CustomJson' => array( 'type' => 'string', ), 'ConfigurationManager' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'UseCustomCookbooks' => array( 'type' => 'boolean', ), 'CustomCookbooksSource' => array( 'type' => 'object', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'DefaultSshKeyName' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), 'DefaultRootDeviceType' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeTimeBasedAutoScalingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TimeBasedAutoScalingConfigurations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TimeBasedAutoScalingConfiguration', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'AutoScalingSchedule' => array( 'type' => 'object', 'properties' => array( 'Monday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Tuesday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Wednesday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Thursday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Friday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Saturday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Sunday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeUserProfilesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UserProfiles' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'UserProfile', 'type' => 'object', 'properties' => array( 'IamUserArn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'SshUsername' => array( 'type' => 'string', ), 'SshPublicKey' => array( 'type' => 'string', ), 'AllowSelfManagement' => array( 'type' => 'boolean', ), ), ), ), ), ), 'DescribeVolumesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Volumes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Volume', 'type' => 'object', 'properties' => array( 'VolumeId' => array( 'type' => 'string', ), 'Ec2VolumeId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'RaidArrayId' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Size' => array( 'type' => 'numeric', ), 'Device' => array( 'type' => 'string', ), 'MountPoint' => array( 'type' => 'string', ), 'Region' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), ), ), ), ), ), 'GetHostnameSuggestionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LayerId' => array( 'type' => 'string', 'location' => 'json', ), 'Hostname' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'RegisterElasticIpResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ElasticIp' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'RegisterVolumeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeApps' => array( 'result_key' => 'Apps', ), 'DescribeCommands' => array( 'result_key' => 'Commands', ), 'DescribeDeployments' => array( 'result_key' => 'Deployments', ), 'DescribeElasticIps' => array( 'result_key' => 'ElasticIps', ), 'DescribeElasticLoadBalancers' => array( 'result_key' => 'ElasticLoadBalancers', ), 'DescribeInstances' => array( 'result_key' => 'Instances', ), 'DescribeLayers' => array( 'result_key' => 'Layers', ), 'DescribeLoadBasedAutoScaling' => array( 'result_key' => 'LoadBasedAutoScalingConfigurations', ), 'DescribeRaidArrays' => array( 'result_key' => 'RaidArrays', ), 'DescribeServiceErrors' => array( 'result_key' => 'ServiceErrors', ), 'DescribeStacks' => array( 'result_key' => 'Stacks', ), 'DescribeTimeBasedAutoScaling' => array( 'result_key' => 'TimeBasedAutoScalingConfigurations', ), 'DescribeUserProfiles' => array( 'result_key' => 'UserProfiles', ), 'DescribeVolumes' => array( 'result_key' => 'Volumes', ), ), ), ); sdk-2.5.2/Aws/Rds/RdsClient.php000064411532700161006750000002477512272324172013307 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/rds-%s.php' )) ->build(); } } sdk-2.5.2/Aws/Rds/Enum/ApplyMethod.php000064411532700161006750000000144412272324172014536 0ustar '2013-09-09', 'endpointPrefix' => 'rds', 'serviceFullName' => 'Amazon Relational Database Service', 'serviceAbbreviation' => 'Amazon RDS', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Rds', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AddSourceIdentifierToSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddSourceIdentifierToSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'The requested source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'AddTagsToResource' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddTagsToResource', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ResourceName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'AuthorizeDBSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeDBSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CIDRIP' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'The state of the DB security group does not allow deletion.', 'class' => 'InvalidDBSecurityGroupStateException', ), array( 'reason' => 'The specified CIDRIP or EC2 security group is already authorized for the specified DB security group.', 'class' => 'AuthorizationAlreadyExistsException', ), array( 'reason' => 'DB security group authorization quota has been reached.', 'class' => 'AuthorizationQuotaExceededException', ), ), ), 'CopyDBSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CopyDBSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SourceDBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TargetDBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBSnapshotIdentifier is already used by an existing snapshot.', 'class' => 'DBSnapshotAlreadyExistsException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), array( 'reason' => 'The state of the DB snapshot does not allow deletion.', 'class' => 'InvalidDBSnapshotStateException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB snapshots.', 'class' => 'SnapshotQuotaExceededException', ), ), ), 'CreateDBInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AllocatedStorage' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Engine' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MasterUsername' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MasterUserPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DBSecurityGroups.member', 'items' => array( 'name' => 'DBSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcSecurityGroupIds.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PreferredBackupWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseModel' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CharacterSetName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB instances.', 'class' => 'InstanceQuotaExceededException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'CreateDBInstanceReadReplica' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBInstanceReadReplica', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceDBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB instances.', 'class' => 'InstanceQuotaExceededException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), array( 'reason' => 'Indicates that the DBSubnetGroup should not be specified while creating read replicas that lie in the same region as the source instance.', 'class' => 'DBSubnetGroupNotAllowedException', ), array( 'reason' => 'Indicates the DBSubnetGroup does not belong to the same VPC as that of an existing cross region read replica of the same source instance.', 'class' => 'InvalidDBSubnetGroupException', ), ), ), 'CreateDBParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Request would result in user exceeding the allowed number of DB parameter groups.', 'class' => 'DBParameterGroupQuotaExceededException', ), array( 'reason' => 'A DB parameter group with the same name exists.', 'class' => 'DBParameterGroupAlreadyExistsException', ), ), ), 'CreateDBSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSecurityGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A DB security group with the name specified in DBSecurityGroupName already exists.', 'class' => 'DBSecurityGroupAlreadyExistsException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB security groups.', 'class' => 'DBSecurityGroupQuotaExceededException', ), array( 'reason' => 'A DB security group is not allowed for this action.', 'class' => 'DBSecurityGroupNotSupportedException', ), ), ), 'CreateDBSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBSnapshotIdentifier is already used by an existing snapshot.', 'class' => 'DBSnapshotAlreadyExistsException', ), array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB snapshots.', 'class' => 'SnapshotQuotaExceededException', ), ), ), 'CreateDBSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBSubnetGroupName is already used by an existing DB subnet group.', 'class' => 'DBSubnetGroupAlreadyExistsException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB subnet groups.', 'class' => 'DBSubnetGroupQuotaExceededException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of subnets in a DB subnet groups.', 'class' => 'DBSubnetQuotaExceededException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), ), ), 'CreateEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'SourceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SourceIds.member', 'items' => array( 'name' => 'SourceId', 'type' => 'string', ), ), 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'You have reached the maximum number of event subscriptions.', 'class' => 'EventSubscriptionQuotaExceededException', ), array( 'reason' => 'The supplied subscription name already exists.', 'class' => 'SubscriptionAlreadyExistException', ), array( 'reason' => 'SNS has responded that there is a problem with the SND topic specified.', 'class' => 'SNSInvalidTopicException', ), array( 'reason' => 'You do not have permission to publish to the SNS topic ARN.', 'class' => 'SNSNoAuthorizationException', ), array( 'reason' => 'The SNS topic ARN does not exist.', 'class' => 'SNSTopicArnNotFoundException', ), array( 'reason' => 'The supplied category does not exist.', 'class' => 'SubscriptionCategoryNotFoundException', ), array( 'reason' => 'The requested source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'CreateOptionGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OptionGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateOptionGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'OptionGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EngineName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MajorEngineVersion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'OptionGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The option group you are trying to create already exists.', 'class' => 'OptionGroupAlreadyExistsException', ), array( 'reason' => 'The quota of 20 option groups was exceeded for this AWS account.', 'class' => 'OptionGroupQuotaExceededException', ), ), ), 'DeleteDBInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SkipFinalSnapshot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'FinalDBSnapshotIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBSnapshotIdentifier is already used by an existing snapshot.', 'class' => 'DBSnapshotAlreadyExistsException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB snapshots.', 'class' => 'SnapshotQuotaExceededException', ), ), ), 'DeleteDBParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The DB parameter group cannot be deleted because it is in use.', 'class' => 'InvalidDBParameterGroupStateException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), ), ), 'DeleteDBSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The state of the DB security group does not allow deletion.', 'class' => 'InvalidDBSecurityGroupStateException', ), array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), ), ), 'DeleteDBSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The state of the DB snapshot does not allow deletion.', 'class' => 'InvalidDBSnapshotStateException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'DeleteDBSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The DB subnet group cannot be deleted because it is in use.', 'class' => 'InvalidDBSubnetGroupStateException', ), array( 'reason' => 'The DB subnet is not in the available state.', 'class' => 'InvalidDBSubnetStateException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), ), ), 'DeleteEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'This error can occur if someone else is modifying a subscription. You should retry the action.', 'class' => 'InvalidEventSubscriptionStateException', ), ), ), 'DeleteOptionGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteOptionGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'OptionGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), array( 'reason' => 'The option group is not in the available state.', 'class' => 'InvalidOptionGroupStateException', ), ), ), 'DescribeDBEngineVersions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBEngineVersionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBEngineVersions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'Engine' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBParameterGroupFamily' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DefaultOnly' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ListSupportedCharacterSets' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DescribeDBInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'DescribeDBLogFiles' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeDBLogFilesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBLogFiles', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'FilenameContains' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FileLastWritten' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'FileSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'DescribeDBParameterGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBParameterGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), ), ), 'DescribeDBParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupDetails', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Source' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), ), ), 'DescribeDBSecurityGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSecurityGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBSecurityGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), ), ), 'DescribeDBSnapshots' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSnapshotMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBSnapshots', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSnapshotIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'DescribeDBSubnetGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSubnetGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBSubnetGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), ), ), 'DescribeEngineDefaultParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EngineDefaultsWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEngineDefaultParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeEventCategories' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventCategoriesMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEventCategories', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeEventSubscriptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEventSubscriptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), ), ), 'DescribeEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SourceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeOptionGroupOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OptionGroupOptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeOptionGroupOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'EngineName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MajorEngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeOptionGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OptionGroups', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeOptionGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'EngineName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MajorEngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'DescribeOrderableDBInstanceOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OrderableDBInstanceOptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeOrderableDBInstanceOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'Engine' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LicenseModel' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Vpc' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeReservedDBInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedDBInstanceMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedDBInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ReservedDBInstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified reserved DB Instance not found.', 'class' => 'ReservedDBInstanceNotFoundException', ), ), ), 'DescribeReservedDBInstancesOfferings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedDBInstancesOfferingMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedDBInstancesOfferings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Specified offering does not exist.', 'class' => 'ReservedDBInstancesOfferingNotFoundException', ), ), ), 'DownloadDBLogFilePortion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DownloadDBLogFilePortionDetails', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DownloadDBLogFilePortion', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LogFileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NumberOfLines' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'ListTagsForResource' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'TagListMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListTagsForResource', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ResourceName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'ModifyDBInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyDBInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AllocatedStorage' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DBSecurityGroups.member', 'items' => array( 'name' => 'DBSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcSecurityGroupIds.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'ApplyImmediately' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'MasterUserPassword' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PreferredBackupWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowMajorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NewDBInstanceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'The state of the DB security group does not allow deletion.', 'class' => 'InvalidDBSecurityGroupStateException', ), array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), array( 'reason' => 'The DB upgrade failed because a resource the DB depends on could not be modified.', 'class' => 'DBUpgradeDependencyFailureException', ), ), ), 'ModifyDBParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyDBParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Parameters' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'ApplyMethod' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), array( 'reason' => 'The DB parameter group cannot be deleted because it is in use.', 'class' => 'InvalidDBParameterGroupStateException', ), ), ), 'ModifyDBSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyDBSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of subnets in a DB subnet groups.', 'class' => 'DBSubnetQuotaExceededException', ), array( 'reason' => 'The DB subnet is already in use in the Availability Zone.', 'class' => 'SubnetAlreadyInUseException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), ), ), 'ModifyEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You have reached the maximum number of event subscriptions.', 'class' => 'EventSubscriptionQuotaExceededException', ), array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'SNS has responded that there is a problem with the SND topic specified.', 'class' => 'SNSInvalidTopicException', ), array( 'reason' => 'You do not have permission to publish to the SNS topic ARN.', 'class' => 'SNSNoAuthorizationException', ), array( 'reason' => 'The SNS topic ARN does not exist.', 'class' => 'SNSTopicArnNotFoundException', ), array( 'reason' => 'The supplied category does not exist.', 'class' => 'SubscriptionCategoryNotFoundException', ), ), ), 'ModifyOptionGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OptionGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyOptionGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'OptionGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'OptionsToInclude' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToInclude.member', 'items' => array( 'name' => 'OptionConfiguration', 'type' => 'object', 'properties' => array( 'OptionName' => array( 'required' => true, 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'DBSecurityGroupMemberships' => array( 'type' => 'array', 'sentAs' => 'DBSecurityGroupMemberships.member', 'items' => array( 'name' => 'DBSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupMemberships' => array( 'type' => 'array', 'sentAs' => 'VpcSecurityGroupMemberships.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'OptionSettings' => array( 'type' => 'array', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'OptionSetting', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'IsCollection' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), ), ), 'OptionsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToRemove.member', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'ApplyImmediately' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The option group is not in the available state.', 'class' => 'InvalidOptionGroupStateException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'PromoteReadReplica' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PromoteReadReplica', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PreferredBackupWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'PurchaseReservedDBInstancesOffering' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedDBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PurchaseReservedDBInstancesOffering', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ReservedDBInstancesOfferingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReservedDBInstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Specified offering does not exist.', 'class' => 'ReservedDBInstancesOfferingNotFoundException', ), array( 'reason' => 'User already has a reservation with the given identifier.', 'class' => 'ReservedDBInstanceAlreadyExistsException', ), array( 'reason' => 'Request would exceed the user\'s DB Instance quota.', 'class' => 'ReservedDBInstanceQuotaExceededException', ), ), ), 'RebootDBInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebootDBInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ForceFailover' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'RemoveSourceIdentifierFromSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemoveSourceIdentifierFromSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'The requested source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'RemoveTagsFromResource' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemoveTagsFromResource', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ResourceName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TagKeys' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'TagKeys.member', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'ResetDBParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetDBParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ResetAllParameters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'ApplyMethod' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The DB parameter group cannot be deleted because it is in use.', 'class' => 'InvalidDBParameterGroupStateException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), ), ), 'RestoreDBInstanceFromDBSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RestoreDBInstanceFromDBSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseModel' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Engine' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB instances.', 'class' => 'InstanceQuotaExceededException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'The state of the DB snapshot does not allow deletion.', 'class' => 'InvalidDBSnapshotStateException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Cannot restore from vpc backup to non-vpc DB instance.', 'class' => 'InvalidRestoreException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'RestoreDBInstanceToPointInTime' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RestoreDBInstanceToPointInTime', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SourceDBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TargetDBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RestoreTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'UseLatestRestorableTime' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseModel' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Engine' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB instances.', 'class' => 'InstanceQuotaExceededException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'SourceDBInstanceIdentifier refers to a DB instance with BackupRetentionPeriod equal to 0.', 'class' => 'PointInTimeRestoreNotEnabledException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Cannot restore from vpc backup to non-vpc DB instance.', 'class' => 'InvalidRestoreException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'RevokeDBSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeDBSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CIDRIP' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group.', 'class' => 'AuthorizationNotFoundException', ), array( 'reason' => 'The state of the DB security group does not allow deletion.', 'class' => 'InvalidDBSecurityGroupStateException', ), ), ), ), 'models' => array( 'EventSubscriptionWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EventSubscription' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CustomerAwsId' => array( 'type' => 'string', ), 'CustSubscriptionId' => array( 'type' => 'string', ), 'SnsTopicArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubscriptionCreationTime' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'SourceIdsList' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceId', 'type' => 'string', 'sentAs' => 'SourceId', ), ), 'EventCategoriesList' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DBSecurityGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBSecurityGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'OwnerId' => array( 'type' => 'string', ), 'DBSecurityGroupName' => array( 'type' => 'string', ), 'DBSecurityGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupId' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), 'IPRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IPRange', 'type' => 'object', 'sentAs' => 'IPRange', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CIDRIP' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DBSnapshotWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBSnapshot' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBSnapshotIdentifier' => array( 'type' => 'string', ), 'DBInstanceIdentifier' => array( 'type' => 'string', ), 'SnapshotCreateTime' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'Status' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'InstanceCreateTime' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'LicenseModel' => array( 'type' => 'string', ), 'SnapshotType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'OptionGroupName' => array( 'type' => 'string', ), 'PercentProgress' => array( 'type' => 'numeric', ), 'SourceRegion' => array( 'type' => 'string', ), ), ), ), ), 'DBInstanceWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBInstance' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBInstanceIdentifier' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'DBInstanceStatus' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'DBName' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'InstanceCreateTime' => array( 'type' => 'string', ), 'PreferredBackupWindow' => array( 'type' => 'string', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', ), 'DBSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'DBSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroupMembership', 'type' => 'object', 'sentAs' => 'VpcSecurityGroupMembership', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'DBParameterGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'DBParameterGroup', 'type' => 'object', 'sentAs' => 'DBParameterGroup', 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), ), ), ), 'AvailabilityZone' => array( 'type' => 'string', ), 'DBSubnetGroup' => array( 'type' => 'object', 'properties' => array( 'DBSubnetGroupName' => array( 'type' => 'string', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'DBInstanceClass' => array( 'type' => 'string', ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'MasterUserPassword' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'EngineVersion' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'DBInstanceIdentifier' => array( 'type' => 'string', ), ), ), 'LatestRestorableTime' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'EngineVersion' => array( 'type' => 'string', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', ), 'ReadReplicaSourceDBInstanceIdentifier' => array( 'type' => 'string', ), 'ReadReplicaDBInstanceIdentifiers' => array( 'type' => 'array', 'items' => array( 'name' => 'ReadReplicaDBInstanceIdentifier', 'type' => 'string', 'sentAs' => 'ReadReplicaDBInstanceIdentifier', ), ), 'LicenseModel' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'OptionGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionGroupMembership', 'type' => 'object', 'sentAs' => 'OptionGroupMembership', 'properties' => array( 'OptionGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'CharacterSetName' => array( 'type' => 'string', ), 'SecondaryAvailabilityZone' => array( 'type' => 'string', ), 'PubliclyAccessible' => array( 'type' => 'boolean', ), 'StatusInfos' => array( 'type' => 'array', 'items' => array( 'name' => 'DBInstanceStatusInfo', 'type' => 'object', 'sentAs' => 'DBInstanceStatusInfo', 'properties' => array( 'StatusType' => array( 'type' => 'string', ), 'Normal' => array( 'type' => 'boolean', ), 'Status' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DBParameterGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBParameterGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', ), 'DBParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), 'DBSubnetGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBSubnetGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBSubnetGroupName' => array( 'type' => 'string', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'OptionGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OptionGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'OptionGroupName' => array( 'type' => 'string', ), 'OptionGroupDescription' => array( 'type' => 'string', ), 'EngineName' => array( 'type' => 'string', ), 'MajorEngineVersion' => array( 'type' => 'string', ), 'Options' => array( 'type' => 'array', 'items' => array( 'name' => 'Option', 'type' => 'object', 'sentAs' => 'Option', 'properties' => array( 'OptionName' => array( 'type' => 'string', ), 'OptionDescription' => array( 'type' => 'string', ), 'Persistent' => array( 'type' => 'boolean', ), 'Permanent' => array( 'type' => 'boolean', ), 'Port' => array( 'type' => 'numeric', ), 'OptionSettings' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionSetting', 'type' => 'object', 'sentAs' => 'OptionSetting', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'IsCollection' => array( 'type' => 'boolean', ), ), ), ), 'DBSecurityGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'DBSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroupMembership', 'type' => 'object', 'sentAs' => 'VpcSecurityGroupMembership', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), ), ), ), 'AllowsVpcAndNonVpcInstanceMemberships' => array( 'type' => 'boolean', ), 'VpcId' => array( 'type' => 'string', ), ), ), ), ), 'DBEngineVersionMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBEngineVersions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBEngineVersion', 'type' => 'object', 'sentAs' => 'DBEngineVersion', 'properties' => array( 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'DBParameterGroupFamily' => array( 'type' => 'string', ), 'DBEngineDescription' => array( 'type' => 'string', ), 'DBEngineVersionDescription' => array( 'type' => 'string', ), 'DefaultCharacterSet' => array( 'type' => 'object', 'properties' => array( 'CharacterSetName' => array( 'type' => 'string', ), 'CharacterSetDescription' => array( 'type' => 'string', ), ), ), 'SupportedCharacterSets' => array( 'type' => 'array', 'items' => array( 'name' => 'CharacterSet', 'type' => 'object', 'sentAs' => 'CharacterSet', 'properties' => array( 'CharacterSetName' => array( 'type' => 'string', ), 'CharacterSetDescription' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DBInstanceMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBInstances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBInstance', 'type' => 'object', 'sentAs' => 'DBInstance', 'properties' => array( 'DBInstanceIdentifier' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'DBInstanceStatus' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'DBName' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'InstanceCreateTime' => array( 'type' => 'string', ), 'PreferredBackupWindow' => array( 'type' => 'string', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', ), 'DBSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'DBSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroupMembership', 'type' => 'object', 'sentAs' => 'VpcSecurityGroupMembership', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'DBParameterGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'DBParameterGroup', 'type' => 'object', 'sentAs' => 'DBParameterGroup', 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), ), ), ), 'AvailabilityZone' => array( 'type' => 'string', ), 'DBSubnetGroup' => array( 'type' => 'object', 'properties' => array( 'DBSubnetGroupName' => array( 'type' => 'string', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'DBInstanceClass' => array( 'type' => 'string', ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'MasterUserPassword' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'EngineVersion' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'DBInstanceIdentifier' => array( 'type' => 'string', ), ), ), 'LatestRestorableTime' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'EngineVersion' => array( 'type' => 'string', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', ), 'ReadReplicaSourceDBInstanceIdentifier' => array( 'type' => 'string', ), 'ReadReplicaDBInstanceIdentifiers' => array( 'type' => 'array', 'items' => array( 'name' => 'ReadReplicaDBInstanceIdentifier', 'type' => 'string', 'sentAs' => 'ReadReplicaDBInstanceIdentifier', ), ), 'LicenseModel' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'OptionGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionGroupMembership', 'type' => 'object', 'sentAs' => 'OptionGroupMembership', 'properties' => array( 'OptionGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'CharacterSetName' => array( 'type' => 'string', ), 'SecondaryAvailabilityZone' => array( 'type' => 'string', ), 'PubliclyAccessible' => array( 'type' => 'boolean', ), 'StatusInfos' => array( 'type' => 'array', 'items' => array( 'name' => 'DBInstanceStatusInfo', 'type' => 'object', 'sentAs' => 'DBInstanceStatusInfo', 'properties' => array( 'StatusType' => array( 'type' => 'string', ), 'Normal' => array( 'type' => 'boolean', ), 'Status' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeDBLogFilesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DescribeDBLogFiles' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DescribeDBLogFilesDetails', 'type' => 'object', 'sentAs' => 'DescribeDBLogFilesDetails', 'properties' => array( 'LogFileName' => array( 'type' => 'string', ), 'LastWritten' => array( 'type' => 'numeric', ), 'Size' => array( 'type' => 'numeric', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DBParameterGroupsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBParameterGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBParameterGroup', 'type' => 'object', 'sentAs' => 'DBParameterGroup', 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', ), 'DBParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'DBParameterGroupDetails' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Parameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'ApplyMethod' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DBSecurityGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBSecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'OwnerId' => array( 'type' => 'string', ), 'DBSecurityGroupName' => array( 'type' => 'string', ), 'DBSecurityGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupId' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), 'IPRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IPRange', 'type' => 'object', 'sentAs' => 'IPRange', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CIDRIP' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DBSnapshotMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBSnapshots' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBSnapshot', 'type' => 'object', 'sentAs' => 'DBSnapshot', 'properties' => array( 'DBSnapshotIdentifier' => array( 'type' => 'string', ), 'DBInstanceIdentifier' => array( 'type' => 'string', ), 'SnapshotCreateTime' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'Status' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'InstanceCreateTime' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'LicenseModel' => array( 'type' => 'string', ), 'SnapshotType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'OptionGroupName' => array( 'type' => 'string', ), 'PercentProgress' => array( 'type' => 'numeric', ), 'SourceRegion' => array( 'type' => 'string', ), ), ), ), ), ), 'DBSubnetGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBSubnetGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBSubnetGroup', 'type' => 'object', 'sentAs' => 'DBSubnetGroup', 'properties' => array( 'DBSubnetGroupName' => array( 'type' => 'string', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'EngineDefaultsWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EngineDefaults' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBParameterGroupFamily' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), 'Parameters' => array( 'type' => 'array', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'ApplyMethod' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EventCategoriesMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EventCategoriesMapList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventCategoriesMap', 'type' => 'object', 'sentAs' => 'EventCategoriesMap', 'properties' => array( 'SourceType' => array( 'type' => 'string', ), 'EventCategories' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), ), ), ), ), ), 'EventSubscriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'EventSubscriptionsList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventSubscription', 'type' => 'object', 'sentAs' => 'EventSubscription', 'properties' => array( 'CustomerAwsId' => array( 'type' => 'string', ), 'CustSubscriptionId' => array( 'type' => 'string', ), 'SnsTopicArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubscriptionCreationTime' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'SourceIdsList' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceId', 'type' => 'string', 'sentAs' => 'SourceId', ), ), 'EventCategoriesList' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), ), 'EventsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Events' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Event', 'type' => 'object', 'sentAs' => 'Event', 'properties' => array( 'SourceIdentifier' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'EventCategories' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Date' => array( 'type' => 'string', ), ), ), ), ), ), 'OptionGroupOptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OptionGroupOptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'OptionGroupOption', 'type' => 'object', 'sentAs' => 'OptionGroupOption', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EngineName' => array( 'type' => 'string', ), 'MajorEngineVersion' => array( 'type' => 'string', ), 'MinimumRequiredMinorEngineVersion' => array( 'type' => 'string', ), 'PortRequired' => array( 'type' => 'boolean', ), 'DefaultPort' => array( 'type' => 'numeric', ), 'OptionsDependedOn' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionName', 'type' => 'string', 'sentAs' => 'OptionName', ), ), 'Persistent' => array( 'type' => 'boolean', ), 'Permanent' => array( 'type' => 'boolean', ), 'OptionGroupOptionSettings' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionGroupOptionSetting', 'type' => 'object', 'sentAs' => 'OptionGroupOptionSetting', 'properties' => array( 'SettingName' => array( 'type' => 'string', ), 'SettingDescription' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'OptionGroups' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OptionGroupsList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'OptionGroup', 'type' => 'object', 'sentAs' => 'OptionGroup', 'properties' => array( 'OptionGroupName' => array( 'type' => 'string', ), 'OptionGroupDescription' => array( 'type' => 'string', ), 'EngineName' => array( 'type' => 'string', ), 'MajorEngineVersion' => array( 'type' => 'string', ), 'Options' => array( 'type' => 'array', 'items' => array( 'name' => 'Option', 'type' => 'object', 'sentAs' => 'Option', 'properties' => array( 'OptionName' => array( 'type' => 'string', ), 'OptionDescription' => array( 'type' => 'string', ), 'Persistent' => array( 'type' => 'boolean', ), 'Permanent' => array( 'type' => 'boolean', ), 'Port' => array( 'type' => 'numeric', ), 'OptionSettings' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionSetting', 'type' => 'object', 'sentAs' => 'OptionSetting', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'IsCollection' => array( 'type' => 'boolean', ), ), ), ), 'DBSecurityGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'DBSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroupMembership', 'type' => 'object', 'sentAs' => 'VpcSecurityGroupMembership', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), ), ), ), 'AllowsVpcAndNonVpcInstanceMemberships' => array( 'type' => 'boolean', ), 'VpcId' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'OrderableDBInstanceOptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OrderableDBInstanceOptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'OrderableDBInstanceOption', 'type' => 'object', 'sentAs' => 'OrderableDBInstanceOption', 'properties' => array( 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'LicenseModel' => array( 'type' => 'string', ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'object', 'sentAs' => 'AvailabilityZone', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), ), 'MultiAZCapable' => array( 'type' => 'boolean', ), 'ReadReplicaCapable' => array( 'type' => 'boolean', ), 'Vpc' => array( 'type' => 'boolean', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedDBInstanceMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedDBInstances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedDBInstance', 'type' => 'object', 'sentAs' => 'ReservedDBInstance', 'properties' => array( 'ReservedDBInstanceId' => array( 'type' => 'string', ), 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'DBInstanceCount' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'State' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ReservedDBInstancesOfferingMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedDBInstancesOfferings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedDBInstancesOffering', 'type' => 'object', 'sentAs' => 'ReservedDBInstancesOffering', 'properties' => array( 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DownloadDBLogFilePortionDetails' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LogFileData' => array( 'type' => 'string', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'AdditionalDataPending' => array( 'type' => 'boolean', 'location' => 'xml', ), ), ), 'TagListMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TagList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'sentAs' => 'Tag', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), 'DBParameterGroupNameMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedDBInstanceWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedDBInstance' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ReservedDBInstanceId' => array( 'type' => 'string', ), 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'DBInstanceCount' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'State' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeDBEngineVersions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBEngineVersions', ), 'DescribeDBInstances' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBInstances', ), 'DescribeDBLogFiles' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DescribeDBLogFiles', ), 'DescribeDBParameterGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBParameterGroups', ), 'DescribeDBParameters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Parameters', ), 'DescribeDBSecurityGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBSecurityGroups', ), 'DescribeDBSnapshots' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBSnapshots', ), 'DescribeDBSubnetGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBSubnetGroups', ), 'DescribeEngineDefaultParameters' => array( 'token_param' => 'Marker', 'limit_key' => 'MaxRecords', ), 'DescribeEventSubscriptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'EventSubscriptionsList', ), 'DescribeEvents' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Events', ), 'DescribeOptionGroupOptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'OptionGroupOptions', ), 'DescribeOptionGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'OptionGroupsList', ), 'DescribeOrderableDBInstanceOptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'OrderableDBInstanceOptions', ), 'DescribeReservedDBInstances' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedDBInstances', ), 'DescribeReservedDBInstancesOfferings' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedDBInstancesOfferings', ), 'DownloadDBLogFilePortion' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', ), 'ListTagsForResource' => array( 'result_key' => 'TagList', ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 30, 'max_attempts' => 60, ), '__DBInstanceState' => array( 'operation' => 'DescribeDBInstances', 'acceptor.path' => 'DBInstances/*/DBInstanceStatus', 'acceptor.type' => 'output', ), 'DBInstanceAvailable' => array( 'extends' => '__DBInstanceState', 'success.value' => 'available', 'failure.value' => array( 'deleted', 'deleting', 'failed', 'incompatible-restore', 'incompatible-parameters', 'incompatible-parameters', 'incompatible-restore', ), ), 'DBInstanceDeleted' => array( 'extends' => '__DBInstanceState', 'success.value' => 'deleted', 'failure.value' => array( 'creating', 'modifying', 'rebooting', 'resetting-master-credentials', ), ), ), ); sdk-2.5.2/Aws/Redshift/RedshiftClient.php000064411532700161006750000002517712272324173015345 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/redshift-%s.php' )) ->build(); } } sdk-2.5.2/Aws/Redshift/Enum/SourceType.php000064411532700161006750000000164312272324173015434 0ustar '2012-12-01', 'endpointPrefix' => 'redshift', 'serviceFullName' => 'Amazon Redshift', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Redshift', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.us-east-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.eu-west-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.ap-southeast-2.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.ap-northeast-1.amazonaws.com', ), ), 'operations' => array( 'AuthorizeClusterSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeClusterSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CIDRIP' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), array( 'reason' => 'The state of the cluster security group is not "available".', 'class' => 'InvalidClusterSecurityGroupStateException', ), array( 'reason' => 'The specified CIDR block or EC2 security group is already authorized for the specified cluster security group.', 'class' => 'AuthorizationAlreadyExistsException', ), array( 'reason' => 'The authorization quota for the cluster security group has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'AuthorizationQuotaExceededException', ), ), ), 'AuthorizeSnapshotAccess' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeSnapshotAccess', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AccountWithRestoreAccess' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), array( 'reason' => 'The specified CIDR block or EC2 security group is already authorized for the specified cluster security group.', 'class' => 'AuthorizationAlreadyExistsException', ), array( 'reason' => 'The authorization quota for the cluster security group has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'AuthorizationQuotaExceededException', ), ), ), 'CopyClusterSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CopyClusterSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SourceSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceSnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'TargetSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value specified as a snapshot identifier is already used by an existing snapshot.', 'class' => 'ClusterSnapshotAlreadyExistsException', ), array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), array( 'reason' => 'The state of the cluster snapshot is not "available", or other accounts are authorized to access the snapshot.', 'class' => 'InvalidClusterSnapshotStateException', ), array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster snapshots.', 'class' => 'ClusterSnapshotQuotaExceededException', ), ), ), 'CreateCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'DBName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ClusterType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NodeType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MasterUsername' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MasterUserPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ClusterSecurityGroups.member', 'items' => array( 'name' => 'ClusterSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcSecurityGroupIds.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'ClusterSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ClusterVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NumberOfNodes' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Encrypted' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'HsmClientCertificateIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ElasticIp' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The account already has a cluster with the given identifier.', 'class' => 'ClusterAlreadyExistsException', ), array( 'reason' => 'The number of nodes specified exceeds the allotted capacity of the cluster.', 'class' => 'InsufficientClusterCapacityException', ), array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), array( 'reason' => 'The request would exceed the allowed number of cluster instances for this account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterQuotaExceededException', ), array( 'reason' => 'The operation would exceed the number of nodes allotted to the account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'NumberOfNodesQuotaExceededException', ), array( 'reason' => 'The operation would exceed the number of nodes allowed for a cluster.', 'class' => 'NumberOfNodesPerClusterLimitExceededException', ), array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), array( 'reason' => 'The cluster subnet group does not cover all Availability Zones.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The cluster subnet group cannot be deleted because it is in use.', 'class' => 'InvalidClusterSubnetGroupStateException', ), array( 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), array( 'reason' => 'The Elastic IP (EIP) is invalid or cannot be found.', 'class' => 'InvalidElasticIpException', ), ), ), 'CreateClusterParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateClusterParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster parameter groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterParameterGroupQuotaExceededException', ), array( 'reason' => 'A cluster parameter group with the same name already exists.', 'class' => 'ClusterParameterGroupAlreadyExistsException', ), ), ), 'CreateClusterSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateClusterSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'A cluster security group with the same name already exists.', 'class' => 'ClusterSecurityGroupAlreadyExistsException', ), array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster security groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterSecurityGroupQuotaExceededException', ), ), ), 'CreateClusterSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateClusterSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value specified as a snapshot identifier is already used by an existing snapshot.', 'class' => 'ClusterSnapshotAlreadyExistsException', ), array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster snapshots.', 'class' => 'ClusterSnapshotQuotaExceededException', ), ), ), 'CreateClusterSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateClusterSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'A ClusterSubnetGroupName is already used by an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupAlreadyExistsException', ), array( 'reason' => 'The request would result in user exceeding the allowed number of cluster subnet groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterSubnetGroupQuotaExceededException', ), array( 'reason' => 'The request would result in user exceeding the allowed number of subnets in a cluster subnet groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterSubnetQuotaExceededException', ), array( 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'CreateEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SourceIds.member', 'items' => array( 'name' => 'SourceId', 'type' => 'string', ), ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'Severity' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request would exceed the allowed number of event subscriptions for this account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'EventSubscriptionQuotaExceededException', ), array( 'reason' => 'There is already an existing event notification subscription with the specified name.', 'class' => 'SubscriptionAlreadyExistException', ), array( 'reason' => 'Amazon SNS has responded that there is a problem with the specified Amazon SNS topic.', 'class' => 'SNSInvalidTopicException', ), array( 'reason' => 'You do not have permission to publish to the specified Amazon SNS topic.', 'class' => 'SNSNoAuthorizationException', ), array( 'reason' => 'An Amazon SNS topic with the specified Amazon Resource Name (ARN) does not exist.', 'class' => 'SNSTopicArnNotFoundException', ), array( 'reason' => 'An Amazon Redshift event with the specified event ID does not exist.', 'class' => 'SubscriptionEventIdNotFoundException', ), array( 'reason' => 'The value specified for the event category was not one of the allowed values, or it specified a category that does not apply to the specified source type. The allowed values are Configuration, Management, Monitoring, and Security.', 'class' => 'SubscriptionCategoryNotFoundException', ), array( 'reason' => 'The value specified for the event severity was not one of the allowed values, or it specified a severity that does not apply to the specified source type. The allowed values are ERROR and INFO.', 'class' => 'SubscriptionSeverityNotFoundException', ), array( 'reason' => 'The specified Amazon Redshift event source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'CreateHsmClientCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'HsmClientCertificateWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateHsmClientCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmClientCertificateIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'There is already an existing Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateAlreadyExistsException', ), array( 'reason' => 'The quota for HSM client certificates has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'HsmClientCertificateQuotaExceededException', ), ), ), 'CreateHsmConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'HsmConfigurationWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateHsmConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmConfigurationIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HsmIpAddress' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HsmPartitionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HsmPartitionPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HsmServerPublicCertificate' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'There is already an existing Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationAlreadyExistsException', ), array( 'reason' => 'The quota for HSM configurations has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'HsmConfigurationQuotaExceededException', ), ), ), 'DeleteCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SkipFinalClusterSnapshot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'FinalClusterSnapshotIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The value specified as a snapshot identifier is already used by an existing snapshot.', 'class' => 'ClusterSnapshotAlreadyExistsException', ), array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster snapshots.', 'class' => 'ClusterSnapshotQuotaExceededException', ), ), ), 'DeleteClusterParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteClusterParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster parameter group action can not be completed because another task is in progress that involves the parameter group. Wait a few moments and try the operation again.', 'class' => 'InvalidClusterParameterGroupStateException', ), array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), ), ), 'DeleteClusterSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteClusterSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The state of the cluster security group is not "available".', 'class' => 'InvalidClusterSecurityGroupStateException', ), array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), ), ), 'DeleteClusterSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteClusterSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The state of the cluster snapshot is not "available", or other accounts are authorized to access the snapshot.', 'class' => 'InvalidClusterSnapshotStateException', ), array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), ), ), 'DeleteClusterSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteClusterSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster subnet group cannot be deleted because it is in use.', 'class' => 'InvalidClusterSubnetGroupStateException', ), array( 'reason' => 'The state of the subnet is invalid.', 'class' => 'InvalidClusterSubnetStateException', ), array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), ), ), 'DeleteEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An Amazon Redshift event notification subscription with the specified name does not exist.', 'class' => 'SubscriptionNotFoundException', ), ), ), 'DeleteHsmClientCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteHsmClientCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmClientCertificateIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified HSM client certificate is not in the available state, or it is still in use by one or more Amazon Redshift clusters.', 'class' => 'InvalidHsmClientCertificateStateException', ), array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), ), ), 'DeleteHsmConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteHsmConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmConfigurationIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified HSM configuration is not in the available state, or it is still in use by one or more Amazon Redshift clusters.', 'class' => 'InvalidHsmConfigurationStateException', ), array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), ), ), 'DescribeClusterParameterGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterParameterGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), ), ), 'DescribeClusterParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupDetails', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Source' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), ), ), 'DescribeClusterSecurityGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSecurityGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterSecurityGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), ), ), 'DescribeClusterSnapshots' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterSnapshots', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OwnerAccount' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), ), ), 'DescribeClusterSubnetGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSubnetGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterSubnetGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), ), ), 'DescribeClusterVersions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterVersionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterVersions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterParameterGroupFamily' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeClusters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClustersMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), ), ), 'DescribeDefaultClusterParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DefaultClusterParametersWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDefaultClusterParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeEventCategories' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventCategoriesMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEventCategories', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeEventSubscriptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEventSubscriptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SubscriptionName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An Amazon Redshift event notification subscription with the specified name does not exist.', 'class' => 'SubscriptionNotFoundException', ), ), ), 'DescribeEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SourceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeHsmClientCertificates' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'HsmClientCertificateMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeHsmClientCertificates', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmClientCertificateIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), ), ), 'DescribeHsmConfigurations' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'HsmConfigurationMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeHsmConfigurations', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), ), ), 'DescribeLoggingStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'LoggingStatus', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoggingStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), ), ), 'DescribeOrderableClusterOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OrderableClusterOptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeOrderableClusterOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NodeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeReservedNodeOfferings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedNodeOfferingsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedNodeOfferings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ReservedNodeOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Specified offering does not exist.', 'class' => 'ReservedNodeOfferingNotFoundException', ), ), ), 'DescribeReservedNodes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedNodesMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedNodes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ReservedNodeId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified reserved compute node not found.', 'class' => 'ReservedNodeNotFoundException', ), ), ), 'DescribeResize' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ResizeProgressMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeResize', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'A resize operation for the specified cluster is not found.', 'class' => 'ResizeNotFoundException', ), ), ), 'DisableLogging' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'LoggingStatus', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableLogging', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), ), ), 'DisableSnapshotCopy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableSnapshotCopy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The cluster already has cross-region snapshot copy disabled.', 'class' => 'SnapshotCopyAlreadyDisabledException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'EnableLogging' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'LoggingStatus', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableLogging', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'BucketName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'Could not find the specified S3 bucket.', 'class' => 'BucketNotFoundException', ), array( 'reason' => 'The cluster does not have read bucket or put object permissions on the S3 bucket specified when enabling logging.', 'class' => 'InsufficientS3BucketPolicyFaultException', ), array( 'reason' => 'The string specified for the logging S3 key prefix does not comply with the documented constraints.', 'class' => 'InvalidS3KeyPrefixFaultException', ), array( 'reason' => 'The S3 bucket name is invalid. For more information about naming rules, go to Bucket Restrictions and Limitations in the Amazon Simple Storage Service (S3) Developer Guide.', 'class' => 'InvalidS3BucketNameFaultException', ), ), ), 'EnableSnapshotCopy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableSnapshotCopy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationRegion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified options are incompatible.', 'class' => 'IncompatibleOrderableOptionsException', ), array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'Cross-region snapshot copy was temporarily disabled. Try your request again.', 'class' => 'CopyToRegionDisabledException', ), array( 'reason' => 'The cluster already has cross-region snapshot copy enabled.', 'class' => 'SnapshotCopyAlreadyEnabledException', ), array( 'reason' => 'The specified region is incorrect or does not exist.', 'class' => 'UnknownSnapshotCopyRegionException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'ModifyCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ClusterType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NodeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NumberOfNodes' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ClusterSecurityGroups.member', 'items' => array( 'name' => 'ClusterSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcSecurityGroupIds.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'MasterUserPassword' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'HsmClientCertificateIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The state of the cluster security group is not "available".', 'class' => 'InvalidClusterSecurityGroupStateException', ), array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The operation would exceed the number of nodes allotted to the account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'NumberOfNodesQuotaExceededException', ), array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), array( 'reason' => 'The number of nodes specified exceeds the allotted capacity of the cluster.', 'class' => 'InsufficientClusterCapacityException', ), array( 'reason' => 'An request option was specified that is not supported.', 'class' => 'UnsupportedOptionException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), ), ), 'ModifyClusterParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyClusterParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Parameters' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), array( 'reason' => 'The cluster parameter group action can not be completed because another task is in progress that involves the parameter group. Wait a few moments and try the operation again.', 'class' => 'InvalidClusterParameterGroupStateException', ), ), ), 'ModifyClusterSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyClusterSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), array( 'reason' => 'The request would result in user exceeding the allowed number of subnets in a cluster subnet groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterSubnetQuotaExceededException', ), array( 'reason' => 'A specified subnet is already in use by another cluster.', 'class' => 'SubnetAlreadyInUseException', ), array( 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'ModifyEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SourceIds.member', 'items' => array( 'name' => 'SourceId', 'type' => 'string', ), ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'Severity' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An Amazon Redshift event notification subscription with the specified name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'Amazon SNS has responded that there is a problem with the specified Amazon SNS topic.', 'class' => 'SNSInvalidTopicException', ), array( 'reason' => 'You do not have permission to publish to the specified Amazon SNS topic.', 'class' => 'SNSNoAuthorizationException', ), array( 'reason' => 'An Amazon SNS topic with the specified Amazon Resource Name (ARN) does not exist.', 'class' => 'SNSTopicArnNotFoundException', ), array( 'reason' => 'An Amazon Redshift event with the specified event ID does not exist.', 'class' => 'SubscriptionEventIdNotFoundException', ), array( 'reason' => 'The value specified for the event category was not one of the allowed values, or it specified a category that does not apply to the specified source type. The allowed values are Configuration, Management, Monitoring, and Security.', 'class' => 'SubscriptionCategoryNotFoundException', ), array( 'reason' => 'The value specified for the event severity was not one of the allowed values, or it specified a severity that does not apply to the specified source type. The allowed values are ERROR and INFO.', 'class' => 'SubscriptionSeverityNotFoundException', ), array( 'reason' => 'The specified Amazon Redshift event source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'ModifySnapshotCopyRetentionPeriod' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifySnapshotCopyRetentionPeriod', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RetentionPeriod' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'Cross-region snapshot copy was temporarily disabled. Try your request again.', 'class' => 'SnapshotCopyDisabledException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'PurchaseReservedNodeOffering' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedNodeWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PurchaseReservedNodeOffering', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ReservedNodeOfferingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NodeCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Specified offering does not exist.', 'class' => 'ReservedNodeOfferingNotFoundException', ), array( 'reason' => 'User already has a reservation with the given identifier.', 'class' => 'ReservedNodeAlreadyExistsException', ), array( 'reason' => 'Request would exceed the user\'s compute node quota. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ReservedNodeQuotaExceededException', ), ), ), 'RebootCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebootCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), ), ), 'ResetClusterParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetClusterParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ResetAllParameters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The cluster parameter group action can not be completed because another task is in progress that involves the parameter group. Wait a few moments and try the operation again.', 'class' => 'InvalidClusterParameterGroupStateException', ), array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), ), ), 'RestoreFromClusterSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RestoreFromClusterSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ClusterSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'OwnerAccount' => array( 'type' => 'string', 'location' => 'aws.query', ), 'HsmClientCertificateIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ElasticIp' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The owner of the specified snapshot has not authorized your account to access the snapshot.', 'class' => 'AccessToSnapshotDeniedException', ), array( 'reason' => 'The account already has a cluster with the given identifier.', 'class' => 'ClusterAlreadyExistsException', ), array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), array( 'reason' => 'The request would exceed the allowed number of cluster instances for this account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterQuotaExceededException', ), array( 'reason' => 'The number of nodes specified exceeds the allotted capacity of the cluster.', 'class' => 'InsufficientClusterCapacityException', ), array( 'reason' => 'The state of the cluster snapshot is not "available", or other accounts are authorized to access the snapshot.', 'class' => 'InvalidClusterSnapshotStateException', ), array( 'reason' => 'The restore is invalid.', 'class' => 'InvalidRestoreException', ), array( 'reason' => 'The operation would exceed the number of nodes allotted to the account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'NumberOfNodesQuotaExceededException', ), array( 'reason' => 'The operation would exceed the number of nodes allowed for a cluster.', 'class' => 'NumberOfNodesPerClusterLimitExceededException', ), array( 'reason' => 'The cluster subnet group does not cover all Availability Zones.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The cluster subnet group cannot be deleted because it is in use.', 'class' => 'InvalidClusterSubnetGroupStateException', ), array( 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), array( 'reason' => 'The Elastic IP (EIP) is invalid or cannot be found.', 'class' => 'InvalidElasticIpException', ), ), ), 'RevokeClusterSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeClusterSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CIDRIP' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), array( 'reason' => 'The specified CIDR IP range or EC2 security group is not authorized for the specified cluster security group.', 'class' => 'AuthorizationNotFoundException', ), array( 'reason' => 'The state of the cluster security group is not "available".', 'class' => 'InvalidClusterSecurityGroupStateException', ), ), ), 'RevokeSnapshotAccess' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeSnapshotAccess', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AccountWithRestoreAccess' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The owner of the specified snapshot has not authorized your account to access the snapshot.', 'class' => 'AccessToSnapshotDeniedException', ), array( 'reason' => 'The specified CIDR IP range or EC2 security group is not authorized for the specified cluster security group.', 'class' => 'AuthorizationNotFoundException', ), array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), ), ), 'RotateEncryptionKey' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RotateEncryptionKey', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), ), ), ), 'models' => array( 'ClusterSecurityGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ClusterSecurityGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ClusterSecurityGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), 'IPRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IPRange', 'type' => 'object', 'sentAs' => 'IPRange', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CIDRIP' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'SnapshotWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Snapshot' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'SnapshotIdentifier' => array( 'type' => 'string', ), 'ClusterIdentifier' => array( 'type' => 'string', ), 'SnapshotCreateTime' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'ClusterCreateTime' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'ClusterVersion' => array( 'type' => 'string', ), 'SnapshotType' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'DBName' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Encrypted' => array( 'type' => 'boolean', ), 'EncryptedWithHSM' => array( 'type' => 'boolean', ), 'AccountsWithRestoreAccess' => array( 'type' => 'array', 'items' => array( 'name' => 'AccountWithRestoreAccess', 'type' => 'object', 'sentAs' => 'AccountWithRestoreAccess', 'properties' => array( 'AccountId' => array( 'type' => 'string', ), ), ), ), 'OwnerAccount' => array( 'type' => 'string', ), 'TotalBackupSizeInMegaBytes' => array( 'type' => 'numeric', ), 'ActualIncrementalBackupSizeInMegaBytes' => array( 'type' => 'numeric', ), 'BackupProgressInMegaBytes' => array( 'type' => 'numeric', ), 'CurrentBackupRateInMegaBytesPerSecond' => array( 'type' => 'numeric', ), 'EstimatedSecondsToCompletion' => array( 'type' => 'numeric', ), 'ElapsedTimeInSeconds' => array( 'type' => 'numeric', ), 'SourceRegion' => array( 'type' => 'string', ), ), ), ), ), 'ClusterWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Cluster' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ClusterIdentifier' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'ClusterStatus' => array( 'type' => 'string', ), 'ModifyStatus' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'DBName' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ClusterCreateTime' => array( 'type' => 'string', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterSecurityGroup', 'type' => 'object', 'sentAs' => 'ClusterSecurityGroup', 'properties' => array( 'ClusterSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroup', 'type' => 'object', 'sentAs' => 'VpcSecurityGroup', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'ClusterParameterGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterParameterGroup', 'type' => 'object', 'sentAs' => 'ClusterParameterGroup', 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), ), ), ), 'ClusterSubnetGroupName' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'MasterUserPassword' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'ClusterType' => array( 'type' => 'string', ), 'ClusterVersion' => array( 'type' => 'string', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', ), ), ), 'ClusterVersion' => array( 'type' => 'string', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'PubliclyAccessible' => array( 'type' => 'boolean', ), 'Encrypted' => array( 'type' => 'boolean', ), 'RestoreStatus' => array( 'type' => 'object', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CurrentRestoreRateInMegaBytesPerSecond' => array( 'type' => 'numeric', ), 'SnapshotSizeInMegaBytes' => array( 'type' => 'numeric', ), 'ProgressInMegaBytes' => array( 'type' => 'numeric', ), 'ElapsedTimeInSeconds' => array( 'type' => 'numeric', ), 'EstimatedTimeToCompletionInSeconds' => array( 'type' => 'numeric', ), ), ), 'HsmStatus' => array( 'type' => 'object', 'properties' => array( 'HsmClientCertificateIdentifier' => array( 'type' => 'string', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), 'ClusterSnapshotCopyStatus' => array( 'type' => 'object', 'properties' => array( 'DestinationRegion' => array( 'type' => 'string', ), 'RetentionPeriod' => array( 'type' => 'numeric', ), ), ), 'ClusterPublicKey' => array( 'type' => 'string', ), 'ClusterNodes' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterNode', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'NodeRole' => array( 'type' => 'string', ), 'PrivateIPAddress' => array( 'type' => 'string', ), 'PublicIPAddress' => array( 'type' => 'string', ), ), ), ), 'ElasticIpStatus' => array( 'type' => 'object', 'properties' => array( 'ElasticIp' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), ), ), ), 'ClusterParameterGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ClusterParameterGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', ), 'ParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), 'ClusterSubnetGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ClusterSubnetGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ClusterSubnetGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EventSubscriptionWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EventSubscription' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CustomerAwsId' => array( 'type' => 'string', ), 'CustSubscriptionId' => array( 'type' => 'string', ), 'SnsTopicArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubscriptionCreationTime' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'SourceIdsList' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceId', 'type' => 'string', 'sentAs' => 'SourceId', ), ), 'EventCategoriesList' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Severity' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), 'HsmClientCertificateWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HsmClientCertificate' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'HsmClientCertificateIdentifier' => array( 'type' => 'string', ), 'HsmClientCertificatePublicKey' => array( 'type' => 'string', ), ), ), ), ), 'HsmConfigurationWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HsmConfiguration' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'HsmConfigurationIdentifier' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'HsmIpAddress' => array( 'type' => 'string', ), 'HsmPartitionName' => array( 'type' => 'string', ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ClusterParameterGroupsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ParameterGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ClusterParameterGroup', 'type' => 'object', 'sentAs' => 'ClusterParameterGroup', 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', ), 'ParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'ClusterParameterGroupDetails' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Parameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ClusterSecurityGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ClusterSecurityGroup', 'type' => 'object', 'sentAs' => 'ClusterSecurityGroup', 'properties' => array( 'ClusterSecurityGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), 'IPRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IPRange', 'type' => 'object', 'sentAs' => 'IPRange', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CIDRIP' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'SnapshotMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Snapshots' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Snapshot', 'type' => 'object', 'sentAs' => 'Snapshot', 'properties' => array( 'SnapshotIdentifier' => array( 'type' => 'string', ), 'ClusterIdentifier' => array( 'type' => 'string', ), 'SnapshotCreateTime' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'ClusterCreateTime' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'ClusterVersion' => array( 'type' => 'string', ), 'SnapshotType' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'DBName' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Encrypted' => array( 'type' => 'boolean', ), 'EncryptedWithHSM' => array( 'type' => 'boolean', ), 'AccountsWithRestoreAccess' => array( 'type' => 'array', 'items' => array( 'name' => 'AccountWithRestoreAccess', 'type' => 'object', 'sentAs' => 'AccountWithRestoreAccess', 'properties' => array( 'AccountId' => array( 'type' => 'string', ), ), ), ), 'OwnerAccount' => array( 'type' => 'string', ), 'TotalBackupSizeInMegaBytes' => array( 'type' => 'numeric', ), 'ActualIncrementalBackupSizeInMegaBytes' => array( 'type' => 'numeric', ), 'BackupProgressInMegaBytes' => array( 'type' => 'numeric', ), 'CurrentBackupRateInMegaBytesPerSecond' => array( 'type' => 'numeric', ), 'EstimatedSecondsToCompletion' => array( 'type' => 'numeric', ), 'ElapsedTimeInSeconds' => array( 'type' => 'numeric', ), 'SourceRegion' => array( 'type' => 'string', ), ), ), ), ), ), 'ClusterSubnetGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ClusterSubnetGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ClusterSubnetGroup', 'type' => 'object', 'sentAs' => 'ClusterSubnetGroup', 'properties' => array( 'ClusterSubnetGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ClusterVersionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ClusterVersions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ClusterVersion', 'type' => 'object', 'sentAs' => 'ClusterVersion', 'properties' => array( 'ClusterVersion' => array( 'type' => 'string', ), 'ClusterParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'ClustersMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Clusters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Cluster', 'type' => 'object', 'sentAs' => 'Cluster', 'properties' => array( 'ClusterIdentifier' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'ClusterStatus' => array( 'type' => 'string', ), 'ModifyStatus' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'DBName' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ClusterCreateTime' => array( 'type' => 'string', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterSecurityGroup', 'type' => 'object', 'sentAs' => 'ClusterSecurityGroup', 'properties' => array( 'ClusterSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroup', 'type' => 'object', 'sentAs' => 'VpcSecurityGroup', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'ClusterParameterGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterParameterGroup', 'type' => 'object', 'sentAs' => 'ClusterParameterGroup', 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), ), ), ), 'ClusterSubnetGroupName' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'MasterUserPassword' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'ClusterType' => array( 'type' => 'string', ), 'ClusterVersion' => array( 'type' => 'string', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', ), ), ), 'ClusterVersion' => array( 'type' => 'string', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'PubliclyAccessible' => array( 'type' => 'boolean', ), 'Encrypted' => array( 'type' => 'boolean', ), 'RestoreStatus' => array( 'type' => 'object', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CurrentRestoreRateInMegaBytesPerSecond' => array( 'type' => 'numeric', ), 'SnapshotSizeInMegaBytes' => array( 'type' => 'numeric', ), 'ProgressInMegaBytes' => array( 'type' => 'numeric', ), 'ElapsedTimeInSeconds' => array( 'type' => 'numeric', ), 'EstimatedTimeToCompletionInSeconds' => array( 'type' => 'numeric', ), ), ), 'HsmStatus' => array( 'type' => 'object', 'properties' => array( 'HsmClientCertificateIdentifier' => array( 'type' => 'string', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), 'ClusterSnapshotCopyStatus' => array( 'type' => 'object', 'properties' => array( 'DestinationRegion' => array( 'type' => 'string', ), 'RetentionPeriod' => array( 'type' => 'numeric', ), ), ), 'ClusterPublicKey' => array( 'type' => 'string', ), 'ClusterNodes' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterNode', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'NodeRole' => array( 'type' => 'string', ), 'PrivateIPAddress' => array( 'type' => 'string', ), 'PublicIPAddress' => array( 'type' => 'string', ), ), ), ), 'ElasticIpStatus' => array( 'type' => 'object', 'properties' => array( 'ElasticIp' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultClusterParametersWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DefaultClusterParameters' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ParameterGroupFamily' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), 'Parameters' => array( 'type' => 'array', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EventCategoriesMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EventCategoriesMapList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventCategoriesMap', 'type' => 'object', 'sentAs' => 'EventCategoriesMap', 'properties' => array( 'SourceType' => array( 'type' => 'string', ), 'Events' => array( 'type' => 'array', 'items' => array( 'name' => 'EventInfoMap', 'type' => 'object', 'sentAs' => 'EventInfoMap', 'properties' => array( 'EventId' => array( 'type' => 'string', ), 'EventCategories' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'EventDescription' => array( 'type' => 'string', ), 'Severity' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'EventSubscriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'EventSubscriptionsList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventSubscription', 'type' => 'object', 'sentAs' => 'EventSubscription', 'properties' => array( 'CustomerAwsId' => array( 'type' => 'string', ), 'CustSubscriptionId' => array( 'type' => 'string', ), 'SnsTopicArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubscriptionCreationTime' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'SourceIdsList' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceId', 'type' => 'string', 'sentAs' => 'SourceId', ), ), 'EventCategoriesList' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Severity' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), ), 'EventsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Events' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Event', 'type' => 'object', 'sentAs' => 'Event', 'properties' => array( 'SourceIdentifier' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'EventCategories' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Severity' => array( 'type' => 'string', ), 'Date' => array( 'type' => 'string', ), 'EventId' => array( 'type' => 'string', ), ), ), ), ), ), 'HsmClientCertificateMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'HsmClientCertificates' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'HsmClientCertificate', 'type' => 'object', 'sentAs' => 'HsmClientCertificate', 'properties' => array( 'HsmClientCertificateIdentifier' => array( 'type' => 'string', ), 'HsmClientCertificatePublicKey' => array( 'type' => 'string', ), ), ), ), ), ), 'HsmConfigurationMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'HsmConfigurations' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'HsmConfiguration', 'type' => 'object', 'sentAs' => 'HsmConfiguration', 'properties' => array( 'HsmConfigurationIdentifier' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'HsmIpAddress' => array( 'type' => 'string', ), 'HsmPartitionName' => array( 'type' => 'string', ), ), ), ), ), ), 'LoggingStatus' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoggingEnabled' => array( 'type' => 'boolean', 'location' => 'xml', ), 'BucketName' => array( 'type' => 'string', 'location' => 'xml', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'xml', ), 'LastSuccessfulDeliveryTime' => array( 'type' => 'string', 'location' => 'xml', ), 'LastFailureTime' => array( 'type' => 'string', 'location' => 'xml', ), 'LastFailureMessage' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'OrderableClusterOptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OrderableClusterOptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'OrderableClusterOption', 'type' => 'object', 'sentAs' => 'OrderableClusterOption', 'properties' => array( 'ClusterVersion' => array( 'type' => 'string', ), 'ClusterType' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'object', 'sentAs' => 'AvailabilityZone', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedNodeOfferingsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedNodeOfferings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedNodeOffering', 'type' => 'object', 'sentAs' => 'ReservedNodeOffering', 'properties' => array( 'ReservedNodeOfferingId' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ReservedNodesMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedNodes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedNode', 'type' => 'object', 'sentAs' => 'ReservedNode', 'properties' => array( 'ReservedNodeId' => array( 'type' => 'string', ), 'ReservedNodeOfferingId' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'NodeCount' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ResizeProgressMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TargetNodeType' => array( 'type' => 'string', 'location' => 'xml', ), 'TargetNumberOfNodes' => array( 'type' => 'numeric', 'location' => 'xml', ), 'TargetClusterType' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'ImportTablesCompleted' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'String', 'type' => 'string', 'sentAs' => 'member', ), ), 'ImportTablesInProgress' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'String', 'type' => 'string', 'sentAs' => 'member', ), ), 'ImportTablesNotStarted' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'String', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'ClusterParameterGroupNameMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', 'location' => 'xml', ), 'ParameterGroupStatus' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedNodeWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedNode' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ReservedNodeId' => array( 'type' => 'string', ), 'ReservedNodeOfferingId' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'NodeCount' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeClusterParameterGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ParameterGroups', ), 'DescribeClusterParameters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Parameters', ), 'DescribeClusterSecurityGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ClusterSecurityGroups', ), 'DescribeClusterSnapshots' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Snapshots', ), 'DescribeClusterSubnetGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ClusterSubnetGroups', ), 'DescribeClusterVersions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ClusterVersions', ), 'DescribeClusters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Clusters', ), 'DescribeDefaultClusterParameters' => array( 'token_param' => 'Marker', 'limit_key' => 'MaxRecords', ), 'DescribeEventSubscriptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'EventSubscriptionsList', ), 'DescribeEvents' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Events', ), 'DescribeHsmClientCertificates' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'HsmClientCertificates', ), 'DescribeHsmConfigurations' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'HsmConfigurations', ), 'DescribeOrderableClusterOptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'OrderableClusterOptions', ), 'DescribeReservedNodeOfferings' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedNodeOfferings', ), 'DescribeReservedNodes' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedNodes', ), ), ), 'waiters' => array( '__default__' => array( 'acceptor.type' => 'output', ), '__ClusterState' => array( 'interval' => 60, 'max_attempts' => 30, 'operation' => 'DescribeClusters', 'acceptor.path' => 'Clusters/*/ClusterStatus', ), 'ClusterAvailable' => array( 'extends' => '__ClusterState', 'success.value' => 'available', 'failure.value' => array( 'deleting', ), 'ignore_errors' => array( 'ClusterNotFound', ), ), 'ClusterDeleted' => array( 'extends' => '__ClusterState', 'success.type' => 'error', 'success.value' => 'ClusterNotFound', 'failure.value' => array( 'creating', 'rebooting', ), ), 'SnapshotAvailable' => array( 'interval' => 15, 'max_attempts' => 20, 'operation' => 'DescribeClusterSnapshots', 'acceptor.path' => 'Snapshots/*/Status', 'success.value' => 'available', 'failure.value' => array( 'failed', 'deleted', ), ), ), ); sdk-2.5.2/Aws/Route53/Route53Client.php000064411532700161006750000001105212272324173014524 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/route53-%s.php' )) ->build(); } /** * Retrieves the server time from Route53. Can be useful for detecting and/or preventing clock skew. * * @return \DateTime The server time from Route53 * @link http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/RESTAuthentication.html#FetchingDate */ public function getServerTime() { try { $response = $this->get('https://route53.amazonaws.com/date')->send(); } catch (ServiceResponseException $e) { $response = $e->getResponse(); } $serverTime = trim($response->getHeader('Date', true)); $serverTime = \DateTime::createFromFormat(DateFormat::RFC1123, $serverTime); return $serverTime; } /** * Filter function used to remove ID prefixes. This is used automatically by the client so that Hosted Zone and * Change Record IDs can be specified with or without the prefix. * * @param string $id The ID value to clean * * @return string */ public static function cleanId($id) { return str_replace(array('/hostedzone/', '/change/'), '', $id); } } sdk-2.5.2/Aws/Route53/Enum/Action.php000064411532700161006750000000141012272324173014235 0ustar '2012-12-12', 'endpointPrefix' => 'route53', 'serviceFullName' => 'Amazon Route 53', 'serviceAbbreviation' => 'Route 53', 'serviceType' => 'rest-xml', 'globalEndpoint' => 'route53.amazonaws.com', 'signatureVersion' => 'v3https', 'namespace' => 'Route53', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), ), 'operations' => array( 'ChangeResourceRecordSets' => array( 'httpMethod' => 'POST', 'uri' => '/2012-12-12/hostedzone/{HostedZoneId}/rrset/', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ChangeResourceRecordSetsResponse', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'ChangeResourceRecordSetsRequest', 'namespaces' => array( 'https://route53.amazonaws.com/doc/2012-12-12/', ), ), ), 'parameters' => array( 'HostedZoneId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'ChangeBatch' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Comment' => array( 'type' => 'string', 'maxLength' => 256, ), 'Changes' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Change', 'type' => 'object', 'properties' => array( 'Action' => array( 'required' => true, 'type' => 'string', ), 'ResourceRecordSet' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'maxLength' => 1024, ), 'Type' => array( 'required' => true, 'type' => 'string', ), 'SetIdentifier' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 128, ), 'Weight' => array( 'type' => 'numeric', 'maximum' => 255, ), 'Region' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'Failover' => array( 'type' => 'string', ), 'TTL' => array( 'type' => 'numeric', 'maximum' => 2147483647, ), 'ResourceRecords' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'ResourceRecord', 'type' => 'object', 'properties' => array( 'Value' => array( 'required' => true, 'type' => 'string', 'maxLength' => 4000, ), ), ), ), 'AliasTarget' => array( 'type' => 'object', 'properties' => array( 'HostedZoneId' => array( 'required' => true, 'type' => 'string', 'maxLength' => 32, ), 'DNSName' => array( 'required' => true, 'type' => 'string', 'maxLength' => 1024, ), 'EvaluateTargetHealth' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'HealthCheckId' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), ), ), ), ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchHostedZoneException', ), array( 'reason' => 'The health check you are trying to get or delete does not exist.', 'class' => 'NoSuchHealthCheckException', ), array( 'reason' => 'This error contains a list of one or more error messages. Each error message indicates one error in the change batch. For more information, see Example InvalidChangeBatch Errors.', 'class' => 'InvalidChangeBatchException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), array( 'reason' => 'The request was rejected because Route 53 was still processing a prior request.', 'class' => 'PriorRequestNotCompleteException', ), ), ), 'CreateHealthCheck' => array( 'httpMethod' => 'POST', 'uri' => '/2012-12-12/healthcheck', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateHealthCheckResponse', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'CreateHealthCheckRequest', 'namespaces' => array( 'https://route53.amazonaws.com/doc/2012-12-12/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', 'minLength' => 1, 'maxLength' => 64, ), 'HealthCheckConfig' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'IPAddress' => array( 'required' => true, 'type' => 'string', 'maxLength' => 15, ), 'Port' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 65535, ), 'Type' => array( 'required' => true, 'type' => 'string', ), 'ResourcePath' => array( 'type' => 'string', 'maxLength' => 255, ), 'FullyQualifiedDomainName' => array( 'type' => 'string', 'maxLength' => 255, ), ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'TooManyHealthChecksException', ), array( 'reason' => 'The health check you are trying to create already exists. Route 53 returns this error when a health check has already been created with the specified CallerReference.', 'class' => 'HealthCheckAlreadyExistsException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'CreateHostedZone' => array( 'httpMethod' => 'POST', 'uri' => '/2012-12-12/hostedzone', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateHostedZoneResponse', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'CreateHostedZoneRequest', 'namespaces' => array( 'https://route53.amazonaws.com/doc/2012-12-12/', ), ), ), 'parameters' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', 'maxLength' => 1024, ), 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', 'minLength' => 1, 'maxLength' => 128, ), 'HostedZoneConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Comment' => array( 'type' => 'string', 'maxLength' => 256, ), ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'This error indicates that the specified domain name is not valid.', 'class' => 'InvalidDomainNameException', ), array( 'reason' => 'The hosted zone you are trying to create already exists. Route 53 returns this error when a hosted zone has already been created with the specified CallerReference.', 'class' => 'HostedZoneAlreadyExistsException', ), array( 'reason' => 'This error indicates that you\'ve reached the maximum number of hosted zones that can be created for the current AWS account. You can request an increase to the limit on the Contact Us page.', 'class' => 'TooManyHostedZonesException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), array( 'reason' => 'Route 53 allows some duplicate domain names, but there is a maximum number of duplicate names. This error indicates that you have reached that maximum. If you want to create another hosted zone with the same name and Route 53 generates this error, you can request an increase to the limit on the Contact Us page.', 'class' => 'DelegationSetNotAvailableException', ), ), ), 'DeleteHealthCheck' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-12-12/healthcheck/{HealthCheckId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteHealthCheckResponse', 'responseType' => 'model', 'parameters' => array( 'HealthCheckId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The health check you are trying to get or delete does not exist.', 'class' => 'NoSuchHealthCheckException', ), array( 'reason' => 'There are resource records associated with this health check. Before you can delete the health check, you must disassociate it from the resource record sets.', 'class' => 'HealthCheckInUseException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'DeleteHostedZone' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-12-12/hostedzone/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteHostedZoneResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchHostedZoneException', ), array( 'reason' => 'The hosted zone contains resource record sets in addition to the default NS and SOA resource record sets. Before you can delete the hosted zone, you must delete the additional resource record sets.', 'class' => 'HostedZoneNotEmptyException', ), array( 'reason' => 'The request was rejected because Route 53 was still processing a prior request.', 'class' => 'PriorRequestNotCompleteException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'GetChange' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/change/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetChangeResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchChangeException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'GetHealthCheck' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/healthcheck/{HealthCheckId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetHealthCheckResponse', 'responseType' => 'model', 'parameters' => array( 'HealthCheckId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 64, ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The health check you are trying to get or delete does not exist.', 'class' => 'NoSuchHealthCheckException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'GetHostedZone' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/hostedzone/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetHostedZoneResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchHostedZoneException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'ListHealthChecks' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/healthcheck', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListHealthChecksResponse', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'marker', 'maxLength' => 64, ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'maxitems', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'ListHostedZones' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/hostedzone', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListHostedZonesResponse', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'marker', 'maxLength' => 64, ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'maxitems', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'ListResourceRecordSets' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/hostedzone/{HostedZoneId}/rrset', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListResourceRecordSetsResponse', 'responseType' => 'model', 'parameters' => array( 'HostedZoneId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'StartRecordName' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'name', 'maxLength' => 1024, ), 'StartRecordType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'type', ), 'StartRecordIdentifier' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'identifier', 'minLength' => 1, 'maxLength' => 128, ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'maxitems', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchHostedZoneException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), ), 'models' => array( 'ChangeResourceRecordSetsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ChangeInfo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubmittedAt' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateHealthCheckResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HealthCheck' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'HealthCheckConfig' => array( 'type' => 'object', 'properties' => array( 'IPAddress' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'Type' => array( 'type' => 'string', ), 'ResourcePath' => array( 'type' => 'string', ), 'FullyQualifiedDomainName' => array( 'type' => 'string', ), ), ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateHostedZoneResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HostedZone' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'Config' => array( 'type' => 'object', 'properties' => array( 'Comment' => array( 'type' => 'string', ), ), ), 'ResourceRecordSetCount' => array( 'type' => 'numeric', ), ), ), 'ChangeInfo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubmittedAt' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'DelegationSet' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'NameServers' => array( 'type' => 'array', 'items' => array( 'name' => 'NameServer', 'type' => 'string', 'sentAs' => 'NameServer', ), ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteHealthCheckResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteHostedZoneResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ChangeInfo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubmittedAt' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetChangeResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ChangeInfo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubmittedAt' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetHealthCheckResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HealthCheck' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'HealthCheckConfig' => array( 'type' => 'object', 'properties' => array( 'IPAddress' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'Type' => array( 'type' => 'string', ), 'ResourcePath' => array( 'type' => 'string', ), 'FullyQualifiedDomainName' => array( 'type' => 'string', ), ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetHostedZoneResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HostedZone' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'Config' => array( 'type' => 'object', 'properties' => array( 'Comment' => array( 'type' => 'string', ), ), ), 'ResourceRecordSetCount' => array( 'type' => 'numeric', ), ), ), 'DelegationSet' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'NameServers' => array( 'type' => 'array', 'items' => array( 'name' => 'NameServer', 'type' => 'string', 'sentAs' => 'NameServer', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListHealthChecksResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HealthChecks' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'HealthCheck', 'type' => 'object', 'sentAs' => 'HealthCheck', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'HealthCheckConfig' => array( 'type' => 'object', 'properties' => array( 'IPAddress' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'Type' => array( 'type' => 'string', ), 'ResourcePath' => array( 'type' => 'string', ), 'FullyQualifiedDomainName' => array( 'type' => 'string', ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListHostedZonesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HostedZones' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'HostedZone', 'type' => 'object', 'sentAs' => 'HostedZone', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'Config' => array( 'type' => 'object', 'properties' => array( 'Comment' => array( 'type' => 'string', ), ), ), 'ResourceRecordSetCount' => array( 'type' => 'numeric', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListResourceRecordSetsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ResourceRecordSets' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ResourceRecordSet', 'type' => 'object', 'sentAs' => 'ResourceRecordSet', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'SetIdentifier' => array( 'type' => 'string', ), 'Weight' => array( 'type' => 'numeric', ), 'Region' => array( 'type' => 'string', ), 'Failover' => array( 'type' => 'string', ), 'TTL' => array( 'type' => 'numeric', ), 'ResourceRecords' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceRecord', 'type' => 'object', 'sentAs' => 'ResourceRecord', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), ), 'AliasTarget' => array( 'type' => 'object', 'properties' => array( 'HostedZoneId' => array( 'type' => 'string', ), 'DNSName' => array( 'type' => 'string', ), 'EvaluateTargetHealth' => array( 'type' => 'boolean', ), ), ), 'HealthCheckId' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'NextRecordName' => array( 'type' => 'string', 'location' => 'xml', ), 'NextRecordType' => array( 'type' => 'string', 'location' => 'xml', ), 'NextRecordIdentifier' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), ), 'iterators' => array( 'operations' => array( 'ListHealthChecks' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'HealthChecks', ), 'ListHostedZones' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'HostedZones', ), 'ListResourceRecordSets' => array( 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'ResourceRecordSets', 'token_param' => array( 'StartRecordName', 'StartRecordType', 'StartRecordIdentifier', ), 'token_key' => array( 'NextRecordName', 'NextRecordType', 'NextRecordIdentifier', ), ), ), ), ); sdk-2.5.2/Aws/S3/AcpListener.php000064411532700161006750000000476212272324173013361 0ustar array('onCommandBeforePrepare', -255)); } /** * An event handler for constructing ACP definitions. * * @param Event $event The event to respond to. * * @throws InvalidArgumentException */ public function onCommandBeforePrepare(Event $event) { /** @var $command \Guzzle\Service\Command\AbstractCommand */ $command = $event['command']; $operation = $command->getOperation(); if ($operation->hasParam('ACP') && $command->hasKey('ACP')) { if ($acp = $command->get('ACP')) { // Ensure that the correct object was passed if (!($acp instanceof Acp)) { throw new InvalidArgumentException('ACP must be an instance of Aws\S3\Model\Acp'); } // Check if the user specified both an ACP and Grants if ($command->hasKey('Grants')) { throw new InvalidArgumentException( 'Use either the ACP parameter or the Grants parameter. Do not use both.' ); } // Add the correct headers/body based parameters to the command if ($operation->hasParam('Grants')) { $command->overwriteWith($acp->toArray()); } else { $acp->updateCommand($command); } } // Remove the ACP parameter $command->remove('ACP'); } } } sdk-2.5.2/Aws/S3/BucketStyleListener.php000064411532700161006750000000575212272324173015114 0ustar array('onCommandAfterPrepare', -255)); } /** * Changes how buckets are referenced in the HTTP request * * @param Event $event Event emitted */ public function onCommandAfterPrepare(Event $event) { $command = $event['command']; $bucket = $command['Bucket']; $request = $command->getRequest(); $pathStyle = false; if ($key = $command['Key']) { // Modify the command Key to account for the {/Key*} explosion into an array if (is_array($key)) { $command['Key'] = $key = implode('/', $key); } } // Set the key and bucket on the request $request->getParams()->set('bucket', $bucket)->set('key', $key); // Switch to virtual if PathStyle is disabled, or not a DNS compatible bucket name, or the scheme is // http, or the scheme is https and there are no dots in the host header (avoids SSL issues) if (!$command['PathStyle'] && $command->getClient()->isValidBucketName($bucket) && !($command->getRequest()->getScheme() == 'https' && strpos($bucket, '.')) ) { // Switch to virtual hosted bucket $request->setHost($bucket . '.' . $request->getHost()); $request->setPath(preg_replace("#^/{$bucket}#", '', $request->getPath())); } else { $pathStyle = true; } if (!$bucket) { $request->getParams()->set('s3.resource', '/'); } elseif ($pathStyle) { // Path style does not need a trailing slash $request->getParams()->set( 's3.resource', '/' . rawurlencode($bucket) . ($key ? ('/' . S3Client::encodeKey($key)) : '') ); } else { // Bucket style needs a trailing slash $request->getParams()->set( 's3.resource', '/' . rawurlencode($bucket) . ($key ? ('/' . S3Client::encodeKey($key)) : '/') ); } } } sdk-2.5.2/Aws/S3/ResumableDownload.php000064411532700161006750000001415312272324173014552 0ustar params = $params; $this->client = $client; $this->params['Bucket'] = $bucket; $this->params['Key'] = $key; // If a string is passed, then assume that the download should stream to a file on disk if (is_string($target)) { if (!($target = fopen($target, 'a+'))) { throw new RuntimeException("Unable to open {$target} for writing"); } // Always append to the file fseek($target, 0, SEEK_END); } // Get the metadata and Content-MD5 of the object $this->target = EntityBody::factory($target); } /** * Get the bucket of the download * * @return string */ public function getBucket() { return $this->params['Bucket']; } /** * Get the key of the download * * @return string */ public function getKey() { return $this->params['Key']; } /** * Get the file to which the contents are downloaded * * @return string */ public function getFilename() { return $this->target->getUri(); } /** * Download the remainder of the object from Amazon S3 * * Performs a message integrity check if possible * * @return Model */ public function __invoke() { $command = $this->client->getCommand('HeadObject', $this->params); $this->meta = $command->execute(); if ($this->target->ftell() >= $this->meta['ContentLength']) { return false; } $this->meta['ContentMD5'] = (string) $command->getResponse()->getHeader('Content-MD5'); // Use a ReadLimitEntityBody so that rewinding the stream after an error does not cause the file pointer // to enter an inconsistent state with the data being downloaded $this->params['SaveAs'] = new ReadLimitEntityBody( $this->target, $this->meta['ContentLength'], $this->target->ftell() ); $result = $this->getRemaining(); $this->checkIntegrity(); return $result; } /** * Send the command to get the remainder of the object * * @return Model */ protected function getRemaining() { $current = $this->target->ftell(); $targetByte = $this->meta['ContentLength'] - 1; $this->params['Range'] = "bytes={$current}-{$targetByte}"; // Set the starting offset so that the body is never seeked to before this point in the event of a retry $this->params['SaveAs']->setOffset($current); $command = $this->client->getCommand('GetObject', $this->params); return $command->execute(); } /** * Performs an MD5 message integrity check if possible * * @throws UnexpectedValueException if the message does not validate */ protected function checkIntegrity() { if ($this->target->isReadable() && $expected = $this->meta['ContentMD5']) { $actual = $this->target->getContentMd5(); if ($actual != $expected) { throw new UnexpectedValueException( "Message integrity check failed. Expected {$expected} but got {$actual}." ); } } } } sdk-2.5.2/Aws/S3/S3Client.php000064411532700161006750000007356112272324173012577 0ustar 'ListBuckets', 'GetBucket' => 'ListObjects', 'PutBucket' => 'CreateBucket', // SDK 1.x Aliases 'GetBucketHeaders' => 'HeadBucket', 'GetObjectHeaders' => 'HeadObject', 'SetBucketAcl' => 'PutBucketAcl', 'CreateObject' => 'PutObject', 'DeleteObjects' => 'DeleteMultipleObjects', 'PutObjectCopy' => 'CopyObject', 'SetObjectAcl' => 'PutObjectAcl', 'GetLogs' => 'GetBucketLogging', 'GetVersioningStatus' => 'GetBucketVersioning', 'SetBucketPolicy' => 'PutBucketPolicy', 'CreateBucketNotification' => 'PutBucketNotification', 'GetBucketNotifications' => 'GetBucketNotification', 'CopyPart' => 'UploadPartCopy', 'CreateWebsiteConfig' => 'PutBucketWebsite', 'GetWebsiteConfig' => 'GetBucketWebsite', 'DeleteWebsiteConfig' => 'DeleteBucketWebsite', 'CreateObjectExpirationConfig' => 'PutBucketLifecycle', 'GetObjectExpirationConfig' => 'GetBucketLifecycle', 'DeleteObjectExpirationConfig' => 'DeleteBucketLifecycle', ); /** * @inheritdoc */ protected $directory = __DIR__; /** * Factory method to create a new Amazon S3 client using an array of configuration options. * * @param array|Collection $config Client configuration data * * @return self * @see \Aws\Common\Client\DefaultClient for a list of available configuration options */ public static function factory($config = array()) { $exceptionParser = new S3ExceptionParser(); // Configure the custom exponential backoff plugin for retrying S3 specific errors if (!isset($config[Options::BACKOFF])) { $config[Options::BACKOFF] = self::createBackoffPlugin($exceptionParser); } $config[Options::SIGNATURE] = $signature = self::createSignature($config); $client = ClientBuilder::factory(__NAMESPACE__) ->setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/s3-%s.php' )) ->setExceptionParser($exceptionParser) ->setIteratorsConfig(array( 'more_key' => 'IsTruncated', 'operations' => array( 'ListBuckets', 'ListMultipartUploads' => array( 'limit_param' => 'MaxUploads', 'token_param' => array('KeyMarker', 'UploadIdMarker'), 'token_key' => array('NextKeyMarker', 'NextUploadIdMarker'), ), 'ListObjects' => array( 'limit_param' => 'MaxKeys', 'token_param' => 'Marker', 'token_key' => 'NextMarker', ), 'ListObjectVersions' => array( 'limit_param' => 'MaxKeys', 'token_param' => array('KeyMarker', 'VersionIdMarker'), 'token_key' => array('nextKeyMarker', 'nextVersionIdMarker'), ), 'ListParts' => array( 'limit_param' => 'MaxParts', 'result_key' => 'Parts', 'token_param' => 'PartNumberMarker', 'token_key' => 'NextPartNumberMarker', ), ) )) ->build(); // Use virtual hosted buckets when possible $client->addSubscriber(new BucketStyleListener()); // Ensure that ACP headers are applied when needed $client->addSubscriber(new AcpListener()); // Validate and add required Content-MD5 hashes (e.g. DeleteObjects) $client->addSubscriber(new S3Md5Listener($signature)); // Allow for specifying bodies with file paths and file handles $client->addSubscriber(new UploadBodyListener(array('PutObject', 'UploadPart'))); // Add aliases for some S3 operations $default = CompositeFactory::getDefaultChain($client); $default->add( new AliasFactory($client, self::$commandAliases), 'Guzzle\Service\Command\Factory\ServiceDescriptionFactory' ); $client->setCommandFactory($default); return $client; } /** * Create an Amazon S3 specific backoff plugin * * @param S3ExceptionParser $exceptionParser * * @return BackoffPlugin */ private static function createBackoffPlugin(S3ExceptionParser $exceptionParser) { return new BackoffPlugin( new TruncatedBackoffStrategy(3, new HttpBackoffStrategy(null, new SocketTimeoutChecker( new CurlBackoffStrategy(null, new ExpiredCredentialsChecker($exceptionParser, new ExponentialBackoffStrategy() ) ) ) ) ) ); } /** * Create an appropriate signature based on the configuration settings * * @param $config * * @return S3Signature * @throws InvalidArgumentException */ private static function createSignature($config) { $currentValue = isset($config[Options::SIGNATURE]) ? $config[Options::SIGNATURE] : null; // Use the Amazon S3 signature V4 when the value is set to "v4" or when // the value is not set and the region starts with "cn-". if ($currentValue == 'v4' || (!$currentValue && isset($config['region']) && substr($config['region'], 0, 3) == 'cn-') ) { // Force SignatureV4 for specific regions or if specified in the config $currentValue = new S3SignatureV4('s3'); } elseif (!$currentValue || $currentValue == 's3') { // Use the Amazon S3 signature by default $currentValue = new S3Signature(); } if ($currentValue instanceof S3SignatureInterface) { // A region is require with v4 if ($currentValue instanceof SignatureV4 && !isset($config['region'])) { throw new InvalidArgumentException('A region must be specified ' . 'when using signature version 4'); } return $currentValue; } throw new InvalidArgumentException('The provided signature value is ' . 'not an instance of S3SignatureInterface'); } /** * Determine if a string is a valid name for a DNS compatible Amazon S3 * bucket, meaning the bucket can be used as a subdomain in a URL (e.g., * ".s3.amazonaws.com"). * * @param string $bucket The name of the bucket to check. * * @return bool TRUE if the bucket name is valid or FALSE if it is invalid. */ public static function isValidBucketName($bucket) { $bucketLen = strlen($bucket); if ($bucketLen < 3 || $bucketLen > 63 || // Cannot start or end with a '.' $bucket[0] == '.' || $bucket[$bucketLen - 1] == '.' || // Cannot look like an IP address preg_match('/(\d+\.){3}\d+$/', $bucket) || // Cannot include special characters, must start and end with lower alnum !preg_match('/^[a-z0-9][a-z0-9\-\.]*[a-z0-9]?$/', $bucket) ) { return false; } return true; } /** * Create a pre-signed URL for a request * * @param RequestInterface $request Request to generate the URL for. Use the factory methods of the client to * create this request object * @param int|string|\DateTime $expires The time at which the URL should expire. This can be a Unix timestamp, a * PHP DateTime object, or a string that can be evaluated by strtotime * * @return string * @throws InvalidArgumentException if the request is not associated with this client object */ public function createPresignedUrl(RequestInterface $request, $expires) { if ($request->getClient() !== $this) { throw new InvalidArgumentException('The request object must be associated with the client. Use the ' . '$client->get(), $client->head(), $client->post(), $client->put(), etc. methods when passing in a ' . 'request object'); } return $this->signature->createPresignedUrl($request, $this->credentials, $expires); } /** * Returns the URL to an object identified by its bucket and key. If an expiration time is provided, the URL will * be signed and set to expire at the provided time. * * @param string $bucket The name of the bucket where the object is located * @param string $key The key of the object * @param mixed $expires The time at which the URL should expire * @param array $args Arguments to the GetObject command. Additionally you can specify a "Scheme" if you would * like the URL to use a different scheme than what the client is configured to use * * @return string The URL to the object */ public function getObjectUrl($bucket, $key, $expires = null, array $args = array()) { $command = $this->getCommand('GetObject', $args + array('Bucket' => $bucket, 'Key' => $key)); if ($command->hasKey('Scheme')) { $scheme = $command['Scheme']; $request = $command->remove('Scheme')->prepare()->setScheme($scheme)->setPort(null); } else { $request = $command->prepare(); } return $expires ? $this->createPresignedUrl($request, $expires) : $request->getUrl(); } /** * Helper used to clear the contents of a bucket. Use the {@see ClearBucket} object directly * for more advanced options and control. * * @param string $bucket Name of the bucket to clear. * * @return int Returns the number of deleted keys */ public function clearBucket($bucket) { $clear = new ClearBucket($this, $bucket); return $clear->clear(); } /** * Determines whether or not a bucket exists by name * * @param string $bucket The name of the bucket * @param bool $accept403 Set to true if 403s are acceptable * @param array $options Additional options to add to the executed command * * @return bool */ public function doesBucketExist($bucket, $accept403 = true, array $options = array()) { return $this->checkExistenceWithCommand( $this->getCommand('HeadBucket', array_merge($options, array( 'Bucket' => $bucket ))), $accept403 ); } /** * Determines whether or not an object exists by name * * @param string $bucket The name of the bucket * @param string $key The key of the object * @param array $options Additional options to add to the executed command * * @return bool */ public function doesObjectExist($bucket, $key, array $options = array()) { return $this->checkExistenceWithCommand( $this->getCommand('HeadObject', array_merge($options, array( 'Bucket' => $bucket, 'Key' => $key ))) ); } /** * Determines whether or not a bucket policy exists for a bucket * * @param string $bucket The name of the bucket * @param array $options Additional options to add to the executed command * * @return bool */ public function doesBucketPolicyExist($bucket, array $options = array()) { return $this->checkExistenceWithCommand( $this->getCommand('GetBucketPolicy', array_merge($options, array( 'Bucket' => $bucket ))) ); } /** * Raw URL encode a key and allow for '/' characters * * @param string $key Key to encode * * @return string Returns the encoded key */ public static function encodeKey($key) { return str_replace('%2F', '/', rawurlencode($key)); } /** * Explode a prefixed key into an array of values * * @param string $key Key to explode * * @return array Returns the exploded */ public static function explodeKey($key) { // Remove a leading slash if one is found return explode('/', $key && $key[0] == '/' ? substr($key, 1) : $key); } /** * Register the Amazon S3 stream wrapper and associates it with this client object * * @return self */ public function registerStreamWrapper() { StreamWrapper::register($this); return $this; } /** * Upload a file, stream, or string to a bucket. If the upload size exceeds the specified threshold, the upload * will be performed using parallel multipart uploads. * * @param string $bucket Bucket to upload the object * @param string $key Key of the object * @param mixed $body Object data to upload. Can be a Guzzle\Http\EntityBodyInterface, stream resource, or * string of data to upload. * @param string $acl ACL to apply to the object * @param array $options Custom options used when executing commands: * - params: Custom parameters to use with the upload. The parameters must map to a PutObject * or InitiateMultipartUpload operation parameters. * - min_part_size: Minimum size to allow for each uploaded part when performing a multipart upload. * - concurrency: Maximum number of concurrent multipart uploads. * - before_upload: Callback to invoke before each multipart upload. The callback will receive a * Guzzle\Common\Event object with context. * * @see Aws\S3\Model\MultipartUpload\UploadBuilder for more options and customization * @return \Guzzle\Service\Resource\Model Returns the modeled result of the performed operation */ public function upload($bucket, $key, $body, $acl = 'private', array $options = array()) { $body = EntityBody::factory($body); $options = Collection::fromConfig(array_change_key_case($options), array( 'min_part_size' => AbstractMulti::MIN_PART_SIZE, 'params' => array(), 'concurrency' => $body->getWrapper() == 'plainfile' ? 3 : 1 )); if ($body->getSize() < $options['min_part_size']) { // Perform a simple PutObject operation return $this->putObject(array( 'Bucket' => $bucket, 'Key' => $key, 'Body' => $body, 'ACL' => $acl ) + $options['params']); } // Perform a multipart upload if the file is large enough $transfer = UploadBuilder::newInstance() ->setBucket($bucket) ->setKey($key) ->setMinPartSize($options['min_part_size']) ->setConcurrency($options['concurrency']) ->setClient($this) ->setSource($body) ->setTransferOptions($options->toArray()) ->addOptions($options['params']) ->setOption('ACL', $acl) ->build() ->upload(); if ($options['before_upload']) { $transfer->getEventDispatcher()->addListener( AbstractTransfer::BEFORE_PART_UPLOAD, $options['before_upload'] ); } return $transfer; } /** * Recursively uploads all files in a given directory to a given bucket. * * @param string $directory Full path to a directory to upload * @param string $bucket Name of the bucket * @param string $keyPrefix Virtual directory key prefix to add to each upload * @param array $options Associative array of upload options * - params: Array of parameters to use with each PutObject operation performed during the transfer * - base_dir: Base directory to remove from each object key * - force: Set to true to upload every file, even if the file is already in Amazon S3 and has not changed * - concurrency: Maximum number of parallel uploads (defaults to 10) * - debug: Set to true or an fopen resource to enable debug mode to print information about each upload * - multipart_upload_size: When the size of a file exceeds this value, the file will be uploaded using a * multipart upload. * * @see Aws\S3\S3Sync\S3Sync for more options and customization */ public function uploadDirectory($directory, $bucket, $keyPrefix = null, array $options = array()) { $options = Collection::fromConfig($options, array('base_dir' => $directory)); $builder = $options['builder'] ?: UploadSyncBuilder::getInstance(); $builder->uploadFromDirectory($directory) ->setClient($this) ->setBucket($bucket) ->setKeyPrefix($keyPrefix) ->setConcurrency($options['concurrency'] ?: 5) ->setBaseDir($options['base_dir']) ->force($options['force']) ->setOperationParams($options['params'] ?: array()) ->enableDebugOutput($options['debug']); if ($options->hasKey('multipart_upload_size')) { $builder->setMultipartUploadSize($options['multipart_upload_size']); } $builder->build()->transfer(); } /** * Downloads a bucket to the local filesystem * * @param string $directory Directory to download to * @param string $bucket Bucket to download from * @param string $keyPrefix Only download objects that use this key prefix * @param array $options Associative array of download options * - params: Array of parameters to use with each GetObject operation performed during the transfer * - base_dir: Base directory to remove from each object key when storing in the local filesystem * - force: Set to true to download every file, even if the file is already on the local filesystem and has not * changed * - concurrency: Maximum number of parallel downloads (defaults to 10) * - debug: Set to true or a fopen resource to enable debug mode to print information about each download * - allow_resumable: Set to true to allow previously interrupted downloads to be resumed using a Range GET */ public function downloadBucket($directory, $bucket, $keyPrefix = '', array $options = array()) { $options = new Collection($options); $builder = $options['builder'] ?: DownloadSyncBuilder::getInstance(); $builder->setDirectory($directory) ->setClient($this) ->setBucket($bucket) ->setKeyPrefix($keyPrefix) ->setConcurrency($options['concurrency'] ?: 10) ->setBaseDir($options['base_dir']) ->force($options['force']) ->setOperationParams($options['params'] ?: array()) ->enableDebugOutput($options['debug']); if ($options['allow_resumable']) { $builder->allowResumableDownloads(); } $builder->build()->transfer(); } /** * Deletes objects from Amazon S3 that match the result of a ListObjects operation. For example, this allows you * to do things like delete all objects that match a specific key prefix. * * @param string $bucket Bucket that contains the object keys * @param string $prefix Optionally delete only objects under this key prefix * @param string $regex Delete only objects that match this regex * @param array $options Options used when deleting the object: * - before_delete: Callback to invoke before each delete. The callback will receive a * Guzzle\Common\Event object with context. * * @see Aws\S3\S3Client::listObjects * @see Aws\S3\Model\ClearBucket For more options or customization * @return int Returns the number of deleted keys * @throws RuntimeException if no prefix and no regex is given */ public function deleteMatchingObjects($bucket, $prefix = '', $regex = '', array $options = array()) { if (!$prefix && !$regex) { throw new RuntimeException('A prefix or regex is required, or use S3Client::clearBucket().'); } $clear = new ClearBucket($this, $bucket); $iterator = $this->getIterator('ListObjects', array('Bucket' => $bucket, 'Prefix' => $prefix)); if ($regex) { $iterator = new FilterIterator($iterator, function ($current) use ($regex) { return preg_match($regex, $current['Key']); }); } $clear->setIterator($iterator); if (isset($options['before_delete'])) { $clear->getEventDispatcher()->addListener(ClearBucket::BEFORE_CLEAR, $options['before_delete']); } return $clear->clear(); } /** * Determines whether or not a resource exists using a command * * @param CommandInterface $command Command used to poll for the resource * @param bool $accept403 Set to true if 403s are acceptable * * @return bool * @throws S3Exception|\Exception if there is an unhandled exception */ protected function checkExistenceWithCommand(CommandInterface $command, $accept403 = false) { try { $command->execute(); $exists = true; } catch (AccessDeniedException $e) { $exists = (bool) $accept403; } catch (S3Exception $e) { $exists = false; if ($e->getResponse()->getStatusCode() >= 500) { // @codeCoverageIgnoreStart throw $e; // @codeCoverageIgnoreEnd } } return $exists; } } sdk-2.5.2/Aws/S3/S3Md5Listener.php000064411532700161006750000000451412272324173013504 0ustar 'onCommandAfterPrepare'); } public function __construct(S3SignatureInterface $signature) { $this->signature = $signature; } public function onCommandAfterPrepare(Event $event) { $command = $event['command']; $operation = $command->getOperation(); if ($operation->getData('contentMd5')) { // Add the MD5 if it is required for all signers $this->addMd5($command); } elseif ($operation->hasParam('ContentMD5')) { $value = $command['ContentMD5']; // Add a computed MD5 if the parameter is set to true or if // not using Signature V4 and the value is not set (null). if ($value === true || ($value === null && !($this->signature instanceof SignatureV4)) ) { $this->addMd5($command); } } } private function addMd5(CommandInterface $command) { $request = $command->getRequest(); if ($body = $request->getBody()) { if (false === ($md5 = $body->getContentMd5(true, true))) { throw new RuntimeException('Unable to add a MD5 checksum'); } $request->setHeader('Content-MD5', $md5); } } } sdk-2.5.2/Aws/S3/S3Signature.php000064411532700161006750000002147312272324173013315 0ustar signableQueryString); // Add the security token header if one is being used by the credentials if ($token = $credentials->getSecurityToken()) { $request->setHeader('x-amz-security-token', $token); } // Add a date header if one is not set if (!$request->hasHeader('date') && !$request->hasHeader('x-amz-date')) { $request->setHeader('Date', gmdate(\DateTime::RFC2822)); } $stringToSign = $this->createCanonicalizedString($request); $request->getParams()->set('aws.string_to_sign', $stringToSign); $request->setHeader( 'Authorization', 'AWS ' . $credentials->getAccessKeyId() . ':' . $this->signString($stringToSign, $credentials) ); } public function createPresignedUrl( RequestInterface $request, CredentialsInterface $credentials, $expires ) { if ($expires instanceof \DateTime) { $expires = $expires->getTimestamp(); } elseif (!is_numeric($expires)) { $expires = strtotime($expires); } // Operate on a clone of the request, so the original is not altered $request = clone $request; // URL encoding already occurs in the URI template expansion. Undo that and encode using the same encoding as // GET object, PUT object, etc. $path = S3Client::encodeKey(rawurldecode($request->getPath())); $request->setPath($path); // Make sure to handle temporary credentials if ($token = $credentials->getSecurityToken()) { $request->setHeader('x-amz-security-token', $token); $request->getQuery()->set('x-amz-security-token', $token); } // Set query params required for pre-signed URLs $request->getQuery() ->set('AWSAccessKeyId', $credentials->getAccessKeyId()) ->set('Expires', $expires) ->set('Signature', $this->signString( $this->createCanonicalizedString($request, $expires), $credentials )); return $request->getUrl(); } public function signString($string, CredentialsInterface $credentials) { return base64_encode(hash_hmac('sha1', $string, $credentials->getSecretKey(), true)); } public function createCanonicalizedString(RequestInterface $request, $expires = null) { $buffer = $request->getMethod() . "\n"; // Add the interesting headers foreach ($this->signableHeaders as $header) { $buffer .= (string) $request->getHeader($header) . "\n"; } // Choose dates from left to right based on what's set $date = $expires ?: (string) $request->getHeader('date'); $buffer .= "{$date}\n" . $this->createCanonicalizedAmzHeaders($request) . $this->createCanonicalizedResource($request); return $buffer; } /** * Create a canonicalized AmzHeaders string for a signature. * * @param RequestInterface $request Request from which to gather headers * * @return string Returns canonicalized AMZ headers. */ private function createCanonicalizedAmzHeaders(RequestInterface $request) { $headers = array(); foreach ($request->getHeaders(true) as $header) { /** @var $header \Guzzle\Http\Message\Header */ $name = strtolower($header->getName()); if (strpos($name, 'x-amz-') === 0) { $value = trim((string) $header); if ($value || $value === '0') { $headers[$name] = $name . ':' . $value; } } } if (empty($headers)) { return ''; } ksort($headers); return implode("\n", $headers) . "\n"; } /** * Create a canonicalized resource for a request * * @param RequestInterface $request Request for the resource * * @return string */ private function createCanonicalizedResource(RequestInterface $request) { $buffer = $request->getParams()->get('s3.resource'); // When sending a raw HTTP request (e.g. $client->get()) if (null === $buffer) { $bucket = $request->getParams()->get('bucket') ?: $this->parseBucketName($request); // Use any specified bucket name, the parsed bucket name, or no bucket name when interacting with GetService $buffer = $bucket ? "/{$bucket}" : ''; // Remove encoding from the path and use the S3 specific encoding $path = S3Client::encodeKey(rawurldecode($request->getPath())); // if the bucket was path style, then ensure that the bucket wasn't duplicated in the resource $buffer .= preg_replace("#^/{$bucket}/{$bucket}#", "/{$bucket}", $path); } // Remove double slashes $buffer = str_replace('//', '/', $buffer); // Add sub resource parameters $query = $request->getQuery(); $first = true; foreach ($this->signableQueryString as $key) { if ($query->hasKey($key)) { $value = $query[$key]; $buffer .= $first ? '?' : '&'; $first = false; $buffer .= $key; // Don't add values for sub-resources if ($value !== '' && $value !== QueryString::BLANK) { $buffer .= "={$value}"; } } } return $buffer; } /** * Parse the bucket name from a request object * * @param RequestInterface $request Request to parse * * @return string */ private function parseBucketName(RequestInterface $request) { $baseUrl = Url::factory($request->getClient()->getBaseUrl()); $baseHost = $baseUrl->getHost(); $host = $request->getHost(); if (strpos($host, $baseHost) === false) { // Does not contain the base URL, so it's either a redirect, CNAME, or using a different region $baseHost = ''; // For every known S3 host, check if that host is present on the request $regions = $request->getClient()->getDescription()->getData('regions'); foreach ($regions as $region) { if (strpos($host, $region['hostname']) !== false) { // This host matches the request host. Tells use the region and endpoint-- we can derive the bucket $baseHost = $region['hostname']; break; } } // If no matching base URL was found, then assume that this is a CNAME, and the CNAME is the bucket if (!$baseHost) { return $host; } } // Remove the baseURL from the host of the request to attempt to determine the bucket name return trim(str_replace($baseHost, '', $request->getHost()), ' .'); } } sdk-2.5.2/Aws/S3/S3SignatureInterface.php000064411532700161006750000000274712272324173015141 0ustar getBody()) { $request->setHeader('X-Amz-Content-Sha256', EntityBody::getHash($request->getBody(), 'sha256')); } else { $request->setHeader('X-Amz-Content-Sha256', hash('sha256', '')); } parent::signRequest($request, $credentials); } public function createPresignedUrl( RequestInterface $request, CredentialsInterface $credentials, $expires ) { $request = clone $request; // Make sure to handle temporary credentials if ($token = $credentials->getSecurityToken()) { $request->setHeader('X-Amz-Security-Token', $token); $request->getQuery()->set('X-Amz-Security-Token', $token); } $this->moveHeadersToQuery($request); $httpDate = $request->getQuery()->get('X-Amz-Date'); $scopeDate = substr($httpDate, 0, 8); $scope = "{$scopeDate}/{$this->regionName}/s3/aws4_request"; $credential = $credentials->getAccessKeyId() . '/' . $scope; $this->addQueryStringValues($request, $credential, $this->convertExpires($expires)); $context = $this->createSigningContext($request, 'UNSIGNED-PAYLOAD'); $signingKey = $this->getSigningKey( $scopeDate, $this->regionName, $this->serviceName, $credentials->getSecretKey() ); $stringToSign = "AWS4-HMAC-SHA256\n{$httpDate}\n{$scope}\n" . hash('sha256', $context['canonical_request']); $request->getQuery()->set( 'X-Amz-Signature', hash_hmac('sha256', $stringToSign, $signingKey) ); return $request->getUrl(); } /** * Overrides the parent class to prevent the removal of dot-segments */ protected function normalizePath(RequestInterface $request) { return '/' . ltrim($request->getPath(), '/'); } private function convertExpires($expires) { if ($expires instanceof \DateTime) { $expires = $expires->getTimestamp(); } elseif (!is_numeric($expires)) { $expires = strtotime($expires); } $duration = $expires - time(); // Ensure that the duration of the signature is not longer than a week if ($duration > 604800) { throw new InvalidArgumentException('The expiration date of an ' . 'Amazon S3 presigned URL using signature version 4 must be ' . 'less than one week.'); } return $duration; } private function moveHeadersToQuery(RequestInterface $request) { $query = array('X-Amz-Date' => gmdate('Ymd\THis\Z', $this->getTimestamp())); foreach ($request->getHeaders() as $name => $header) { if (substr($name, 0, 5) == 'x-amz') { $query[$header->getName()] = (string) $header; } if ($name != 'host') { $request->removeHeader($name); } } $request->getQuery()->overwriteWith($query); } private function addQueryStringValues( RequestInterface $request, $credential, $expires ) { // Set query params required for pre-signed URLs $request->getQuery() ->set('X-Amz-Algorithm', 'AWS4-HMAC-SHA256') ->set('X-Amz-Credential', $credential) ->set('X-Amz-SignedHeaders', 'Host') ->set('X-Amz-Expires', $expires); } } sdk-2.5.2/Aws/S3/SocketTimeoutChecker.php000064411532700161006750000000555112272324173015231 0ustar setNext($next); } } /** * {@inheridoc} */ public function makesDecision() { return true; } /** * {@inheritdoc} */ protected function getDelay( $retries, RequestInterface $request, Response $response = null, HttpException $e = null ) { if ($response && $response->getStatusCode() == 400 && strpos($response->getBody(), self::ERR) ) { // Check if the request is sending a local file, and if so, clear the stat cache and recalculate the size. if ($request instanceof EntityEnclosingRequestInterface) { if ($request->getBody()->getWrapper() == 'plainfile') { $filename = $request->getBody()->getUri(); // Clear the cache so that we send accurate file sizes clearstatcache(true, $filename); $length = filesize($filename); $request->getBody()->setSize($length); $request->setHeader('Content-Length', $length); } } return true; } } } sdk-2.5.2/Aws/S3/StreamWrapper.php000064411532700161006750000006065312272324173013745 0ustar /" files with PHP streams, supporting "r", "w", "a", "x". * * # Supported stream related PHP functions: * - fopen, fclose, fread, fwrite, fseek, ftell, feof, fflush * - opendir, closedir, readdir, rewinddir * - copy, rename, unlink * - mkdir, rmdir, rmdir (recursive) * - file_get_contents, file_put_contents * - file_exists, filesize, is_file, is_dir * * # Opening "r" (read only) streams: * * Read only streams are truly streaming by default and will not allow you to seek. This is because data * read from the stream is not kept in memory or on the local filesystem. You can force a "r" stream to be seekable * by setting the "seekable" stream context option true. This will allow true streaming of data from Amazon S3, but * will maintain a buffer of previously read bytes in a 'php://temp' stream to allow seeking to previously read bytes * from the stream. * * You may pass any GetObject parameters as 's3' stream context options. These options will affect how the data is * downloaded from Amazon S3. * * # Opening "w" and "x" (write only) streams: * * Because Amazon S3 requires a Content-Length header, write only streams will maintain a 'php://temp' stream to buffer * data written to the stream until the stream is flushed (usually by closing the stream with fclose). * * You may pass any PutObject parameters as 's3' stream context options. These options will affect how the data is * uploaded to Amazon S3. * * When opening an "x" stream, the file must exist on Amazon S3 for the stream to open successfully. * * # Opening "a" (write only append) streams: * * Similar to "w" streams, opening append streams requires that the data be buffered in a "php://temp" stream. Append * streams will attempt to download the contents of an object in Amazon S3, seek to the end of the object, then allow * you to append to the contents of the object. The data will then be uploaded using a PutObject operation when the * stream is flushed (usually with fclose). * * You may pass any GetObject and/or PutObject parameters as 's3' stream context options. These options will affect how * the data is downloaded and uploaded from Amazon S3. * * Stream context options: * * - "seekable": Set to true to create a seekable "r" (read only) stream by using a php://temp stream buffer * - "throw_exceptions": Set to true to throw exceptions instead of trigger_errors * - For "unlink" only: Any option that can be passed to the DeleteObject operation */ class StreamWrapper { /** * @var resource|null Stream context (this is set by PHP when a context is used) */ public $context; /** * @var S3Client Client used to send requests */ protected static $client; /** * @var string Mode the stream was opened with */ protected $mode; /** * @var EntityBody Underlying stream resource */ protected $body; /** * @var array Current parameters to use with the flush operation */ protected $params; /** * @var ListObjectsIterator Iterator used with opendir() and subsequent readdir() calls */ protected $objectIterator; /** * @var string The bucket that was opened when opendir() was called */ protected $openedBucket; /** * @var string The prefix of the bucket that was opened with opendir() */ protected $openedBucketPrefix; /** * @var array The next key to retrieve when using a directory iterator. Helps for fast directory traversal. */ protected static $nextStat = array(); /** * Register the 's3://' stream wrapper * * @param S3Client $client Client to use with the stream wrapper */ public static function register(S3Client $client) { if (in_array('s3', stream_get_wrappers())) { stream_wrapper_unregister('s3'); } stream_wrapper_register('s3', __CLASS__, STREAM_IS_URL); self::$client = $client; } /** * Close the stream */ public function stream_close() { $this->body = null; } /** * @param string $path * @param string $mode * @param int $options * @param string $opened_path * * @return bool */ public function stream_open($path, $mode, $options, &$opened_path) { // We don't care about the binary flag $this->mode = $mode = rtrim($mode, 'bt'); $this->params = $params = $this->getParams($path); $errors = array(); if (!$params['Key']) { $errors[] = 'Cannot open a bucket. You must specify a path in the form of s3://bucket/key'; } if (strpos($mode, '+')) { $errors[] = 'The Amazon S3 stream wrapper does not allow simultaneous reading and writing.'; } if (!in_array($mode, array('r', 'w', 'a', 'x'))) { $errors[] = "Mode not supported: {$mode}. Use one 'r', 'w', 'a', or 'x'."; } // When using mode "x" validate if the file exists before attempting to read if ($mode == 'x' && self::$client->doesObjectExist($params['Bucket'], $params['Key'], $this->getOptions())) { $errors[] = "{$path} already exists on Amazon S3"; } if (!$errors) { if ($mode == 'r') { $this->openReadStream($params, $errors); } elseif ($mode == 'a') { $this->openAppendStream($params, $errors); } else { $this->openWriteStream($params, $errors); } } return $errors ? $this->triggerError($errors) : true; } /** * @return bool */ public function stream_eof() { return $this->body->feof(); } /** * @return bool */ public function stream_flush() { if ($this->mode == 'r') { return false; } $this->body->rewind(); $params = $this->params; $params['Body'] = $this->body; // Attempt to guess the ContentType of the upload based on the // file extension of the key if (!isset($params['ContentType']) && ($type = Mimetypes::getInstance()->fromFilename($params['Key'])) ) { $params['ContentType'] = $type; } try { self::$client->putObject($params); return true; } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } } /** * Read data from the underlying stream * * @param int $count Amount of bytes to read * * @return string */ public function stream_read($count) { return $this->body->read($count); } /** * Seek to a specific byte in the stream * * @param int $offset Seek offset * @param int $whence Whence (SEEK_SET, SEEK_CUR, SEEK_END) * * @return bool */ public function stream_seek($offset, $whence = SEEK_SET) { return $this->body->seek($offset, $whence); } /** * Get the current position of the stream * * @return int Returns the current position in the stream */ public function stream_tell() { return $this->body->ftell(); } /** * Write data the to the stream * * @param string $data * * @return int Returns the number of bytes written to the stream */ public function stream_write($data) { return $this->body->write($data); } /** * Delete a specific object * * @param string $path * @return bool */ public function unlink($path) { try { $this->clearStatInfo($path); self::$client->deleteObject($this->getParams($path)); return true; } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } } /** * @return array */ public function stream_stat() { $stat = fstat($this->body->getStream()); // Add the size of the underlying stream if it is known if ($this->mode == 'r' && $this->body->getSize()) { $stat[7] = $stat['size'] = $this->body->getSize(); } return $stat; } /** * Provides information for is_dir, is_file, filesize, etc. Works on buckets, keys, and prefixes * * @param string $path * @param int $flags * * @return array Returns an array of stat data * @link http://www.php.net/manual/en/streamwrapper.url-stat.php */ public function url_stat($path, $flags) { // Check if this path is in the url_stat cache if (isset(self::$nextStat[$path])) { return self::$nextStat[$path]; } $parts = $this->getParams($path); if (!$parts['Key']) { // Stat "directories": buckets, or "s3://" if (!$parts['Bucket'] || self::$client->doesBucketExist($parts['Bucket'])) { return $this->formatUrlStat($path); } else { return $this->triggerError("File or directory not found: {$path}", $flags); } } try { try { $result = self::$client->headObject($parts)->toArray(); if (substr($parts['Key'], -1, 1) == '/' && $result['ContentLength'] == 0) { // Return as if it is a bucket to account for console bucket objects (e.g., zero-byte object "foo/") return $this->formatUrlStat($path); } else { // Attempt to stat and cache regular object return $this->formatUrlStat($result); } } catch (NoSuchKeyException $e) { // Maybe this isn't an actual key, but a prefix. Do a prefix listing of objects to determine. $result = self::$client->listObjects(array( 'Bucket' => $parts['Bucket'], 'Prefix' => rtrim($parts['Key'], '/') . '/', 'MaxKeys' => 1 )); if (!$result['Contents'] && !$result['CommonPrefixes']) { return $this->triggerError("File or directory not found: {$path}", $flags); } // This is a directory prefix return $this->formatUrlStat($path); } } catch (\Exception $e) { return $this->triggerError($e->getMessage(), $flags); } } /** * Support for mkdir(). * * @param string $path Directory which should be created. * @param int $mode Permissions. 700-range permissions map to ACL_PUBLIC. 600-range permissions map to * ACL_AUTH_READ. All other permissions map to ACL_PRIVATE. Expects octal form. * @param int $options A bitwise mask of values, such as STREAM_MKDIR_RECURSIVE. (unused) * * @return bool * @link http://www.php.net/manual/en/streamwrapper.mkdir.php */ public function mkdir($path, $mode, $options) { $params = $this->getParams($path); $this->clearStatInfo($path); if (!$params['Bucket'] || $params['Key']) { return false; } try { if (!isset($params['ACL'])) { $mode = decoct($mode); if ($mode >= 700 and $mode <= 799) { $params['ACL'] = 'public-read'; } elseif ($mode >= 600 && $mode <= 699) { $params['ACL'] = 'authenticated-read'; } else { $params['ACL'] = 'private'; } } self::$client->createBucket($params); return true; } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } } /** * Remove a bucket from Amazon S3 * * @param string $path the directory path * * @return bool true if directory was successfully removed * @link http://www.php.net/manual/en/streamwrapper.rmdir.php */ public function rmdir($path) { $params = $this->getParams($path); if (!$params['Bucket']) { return $this->triggerError('You cannot delete s3://. Please specify a bucket.'); } elseif ($params['Key']) { return $this->triggerError('rmdir() only supports bucket deletion'); } try { self::$client->deleteBucket(array('Bucket' => $params['Bucket'])); $this->clearStatInfo($path); return true; } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } } /** * Support for opendir(). * * @param string $path The path to the directory (e.g. "s3://dir[]") * @param string $options Whether or not to enforce safe_mode (0x04). Unused. * * @return bool true on success * @see http://www.php.net/manual/en/function.opendir.php */ public function dir_opendir($path, $options) { // Reset the cache $this->clearStatInfo(); $params = $this->getParams($path); $delimiter = $this->getOption('delimiter'); if ($delimiter === null) { $delimiter = '/'; } if ($params['Key']) { $params['Key'] = rtrim($params['Key'], $delimiter) . $delimiter; } $this->openedBucket = $params['Bucket']; $this->openedBucketPrefix = $params['Key']; $operationParams = array('Bucket' => $params['Bucket'], 'Prefix' => $params['Key']); if ($delimiter) { $operationParams['Delimiter'] = $delimiter; } $this->objectIterator = self::$client->getIterator('ListObjects', $operationParams, array( 'return_prefixes' => true, 'sort_results' => true )); $this->objectIterator->next(); return true; } /** * Close the directory listing handles * * @return bool true on success */ public function dir_closedir() { $this->objectIterator = null; return true; } /** * This method is called in response to rewinddir() * * @return boolean true on success */ public function dir_rewinddir() { $this->clearStatInfo(); $this->objectIterator->rewind(); return true; } /** * This method is called in response to readdir() * * @return string Should return a string representing the next filename, or false if there is no next file. * * @link http://www.php.net/manual/en/function.readdir.php */ public function dir_readdir() { $result = false; if ($this->objectIterator->valid()) { $current = $this->objectIterator->current(); if (isset($current['Prefix'])) { // Include "directories". Be sure to strip a trailing "/" on prefixes. $prefix = rtrim($current['Prefix'], '/'); $result = str_replace($this->openedBucketPrefix, '', $prefix); $key = "s3://{$this->openedBucket}/{$prefix}"; $stat = $this->formatUrlStat($prefix); } else { // Remove the prefix from the result to emulate other stream wrappers $result = str_replace($this->openedBucketPrefix, '', $current['Key']); $key = "s3://{$this->openedBucket}/{$current['Key']}"; $stat = $this->formatUrlStat($current); } // Cache the object data for quick url_stat lookups used with RecursiveDirectoryIterator self::$nextStat = array($key => $stat); $this->objectIterator->next(); } return $result; } /** * Called in response to rename() to rename a file or directory. Currently only supports renaming objects. * * @param string $path_from the path to the file to rename * @param string $path_to the new path to the file * * @return bool true if file was successfully renamed * @link http://www.php.net/manual/en/function.rename.php */ public function rename($path_from, $path_to) { $partsFrom = $this->getParams($path_from); $partsTo = $this->getParams($path_to); $this->clearStatInfo($path_from); $this->clearStatInfo($path_to); if (!$partsFrom['Key'] || !$partsTo['Key']) { return $this->triggerError('The Amazon S3 stream wrapper only supports copying objects'); } try { // Copy the object and allow overriding default parameters if desired, but by default copy metadata self::$client->copyObject($this->getOptions() + array( 'Bucket' => $partsTo['Bucket'], 'Key' => $partsTo['Key'], 'CopySource' => '/' . $partsFrom['Bucket'] . '/' . rawurlencode($partsFrom['Key']), 'MetadataDirective' => 'COPY' )); // Delete the original object self::$client->deleteObject(array( 'Bucket' => $partsFrom['Bucket'], 'Key' => $partsFrom['Key'] ) + $this->getOptions()); } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } return true; } /** * Cast the stream to return the underlying file resource * * @param int $cast_as STREAM_CAST_FOR_SELECT or STREAM_CAST_AS_STREAM * * @return resource */ public function stream_cast($cast_as) { return $this->body->getStream(); } /** * Get the stream context options available to the current stream * * @return array */ protected function getOptions() { $context = $this->context ?: stream_context_get_default(); $options = stream_context_get_options($context); return isset($options['s3']) ? $options['s3'] : array(); } /** * Get a specific stream context option * * @param string $name Name of the option to retrieve * * @return mixed|null */ protected function getOption($name) { $options = $this->getOptions(); return isset($options[$name]) ? $options[$name] : null; } /** * Get the bucket and key from the passed path (e.g. s3://bucket/key) * * @param string $path Path passed to the stream wrapper * * @return array Hash of 'Bucket', 'Key', and custom params */ protected function getParams($path) { $parts = explode('/', substr($path, 5), 2); $params = $this->getOptions(); unset($params['seekable']); unset($params['throw_exceptions']); return array( 'Bucket' => $parts[0], 'Key' => isset($parts[1]) ? $parts[1] : null ) + $params; } /** * Serialize and sign a command, returning a request object * * @param CommandInterface $command Command to sign * * @return RequestInterface */ protected function getSignedRequest($command) { $request = $command->prepare(); $request->dispatch('request.before_send', array('request' => $request)); return $request; } /** * Initialize the stream wrapper for a read only stream * * @param array $params Operation parameters * @param array $errors Any encountered errors to append to * * @return bool */ protected function openReadStream(array $params, array &$errors) { // Create the command and serialize the request $request = $this->getSignedRequest(self::$client->getCommand('GetObject', $params)); // Create a stream that uses the EntityBody object $factory = $this->getOption('stream_factory') ?: new PhpStreamRequestFactory(); $this->body = $factory->fromRequest($request, array(), array('stream_class' => 'Guzzle\Http\EntityBody')); // Wrap the body in a caching entity body if seeking is allowed if ($this->getOption('seekable')) { $this->body = new CachingEntityBody($this->body); } return true; } /** * Initialize the stream wrapper for a write only stream * * @param array $params Operation parameters * @param array $errors Any encountered errors to append to * * @return bool */ protected function openWriteStream(array $params, array &$errors) { $this->body = new EntityBody(fopen('php://temp', 'r+')); } /** * Initialize the stream wrapper for an append stream * * @param array $params Operation parameters * @param array $errors Any encountered errors to append to * * @return bool */ protected function openAppendStream(array $params, array &$errors) { try { // Get the body of the object $this->body = self::$client->getObject($params)->get('Body'); $this->body->seek(0, SEEK_END); } catch (S3Exception $e) { // The object does not exist, so use a simple write stream $this->openWriteStream($params, $errors); } return true; } /** * Trigger one or more errors * * @param string|array $errors Errors to trigger * @param mixed $flags If set to STREAM_URL_STAT_QUIET, then no error or exception occurs * * @return bool Returns false * @throws RuntimeException if throw_errors is true */ protected function triggerError($errors, $flags = null) { if ($flags != STREAM_URL_STAT_QUIET) { if ($this->getOption('throw_exceptions')) { throw new RuntimeException(implode("\n", (array) $errors)); } else { trigger_error(implode("\n", (array) $errors), E_USER_WARNING); } } return false; } /** * Prepare a url_stat result array * * @param string|array $result Data to add * * @return array Returns the modified url_stat result */ protected function formatUrlStat($result = null) { static $statTemplate = array( 0 => 0, 'dev' => 0, 1 => 0, 'ino' => 0, 2 => 0, 'mode' => 0, 3 => 0, 'nlink' => 0, 4 => 0, 'uid' => 0, 5 => 0, 'gid' => 0, 6 => -1, 'rdev' => -1, 7 => 0, 'size' => 0, 8 => 0, 'atime' => 0, 9 => 0, 'mtime' => 0, 10 => 0, 'ctime' => 0, 11 => -1, 'blksize' => -1, 12 => -1, 'blocks' => -1, ); $stat = $statTemplate; // Determine what type of data is being cached if (!$result || is_string($result)) { // Directory with 0777 access - see "man 2 stat". $stat['mode'] = $stat[2] = 0040777; } elseif (is_array($result) && isset($result['LastModified'])) { // ListObjects or HeadObject result $stat['mtime'] = $stat[9] = $stat['ctime'] = $stat[10] = strtotime($result['LastModified']); $stat['size'] = $stat[7] = (isset($result['ContentLength']) ? $result['ContentLength'] : $result['Size']); // Regular file with 0777 access - see "man 2 stat". $stat['mode'] = $stat[2] = 0100777; } else { $stat['mode'] = $stat[2] = 0100777; } return $stat; } /** * Clear the next stat result from the cache * * @param string $path If a path is specific, clearstatcache() will be called */ protected function clearStatInfo($path = null) { self::$nextStat = array(); if ($path) { clearstatcache(true, $path); } } } sdk-2.5.2/Aws/S3/Command/S3Command.php000064411532700161006750000000373212272324173014306 0ustar client->createPresignedUrl($this->prepare(), $expires); } /** * {@inheritdoc} */ protected function process() { $request = $this->getRequest(); $response = $this->getResponse(); // Dispatch an error if a 301 redirect occurred if ($response->getStatusCode() == 301) { $this->getClient()->getEventDispatcher()->dispatch('request.error', new Event(array( 'request' => $this->getRequest(), 'response' => $response ))); } parent::process(); // Set the GetObject URL if using the PutObject operation if ($this->result instanceof Model && $this->getName() == 'PutObject') { $this->result->set('ObjectURL', $request->getUrl()); } } } sdk-2.5.2/Aws/S3/Enum/CannedAcl.php000064411532700161006750000000177212272324173013662 0ustar errors = $errors; } /** * Get the errored objects * * @return array Returns an array of associative arrays, each containing * a 'Code', 'Message', and 'Key' key. */ public function getErrors() { return $this->errors; } } sdk-2.5.2/Aws/S3/Exception/EntityTooLargeException.php000064411532700161006750000000135312272324173017667 0ustar getStatusCode() === 301) { $data['type'] = 'client'; if (isset($data['message'], $data['parsed'])) { $data['message'] = rtrim($data['message'], '.') . ': "' . $data['parsed']->Endpoint . '".'; } } return $data; } /** * {@inheritdoc} */ protected function parseHeaders(RequestInterface $request, Response $response, array &$data) { parent::parseHeaders($request, $response, $data); // Get the request $status = $response->getStatusCode(); $method = $request->getMethod(); // Attempt to determine code for 403s and 404s if ($status === 403) { $data['code'] = 'AccessDenied'; } elseif ($method === 'HEAD' && $status === 404) { $path = explode('/', trim($request->getPath(), '/')); $host = explode('.', $request->getHost()); $bucket = (count($host) === 4) ? $host[0] : array_shift($path); $object = array_shift($path); if ($bucket && $object) { $data['code'] = 'NoSuchKey'; } elseif ($bucket) { $data['code'] = 'NoSuchBucket'; } } } } sdk-2.5.2/Aws/S3/Iterator/ListBucketsIterator.php000064411532700161006750000000253412272324173016702 0ustar get('Buckets') ?: array(); // If only the names_only set, change arrays to a string if ($this->get('names_only')) { foreach ($buckets as &$bucket) { $bucket = $bucket['Name']; } } return $buckets; } } sdk-2.5.2/Aws/S3/Iterator/ListMultipartUploadsIterator.php000064411532700161006750000000261112272324173020607 0ustar get('Uploads') ?: array(); // If there are prefixes and we want them, merge them in if ($this->get('return_prefixes') && $result->hasKey('CommonPrefixes')) { $uploads = array_merge($uploads, $result->get('CommonPrefixes')); } return $uploads; } } sdk-2.5.2/Aws/S3/Iterator/ListObjectsIterator.php000064411532700161006750000000527312272324173016676 0ustar get('Contents') ?: array(); $numObjects = count($objects); $lastKey = $numObjects ? $objects[$numObjects - 1]['Key'] : false; if ($lastKey && !$result->hasKey($this->get('token_key'))) { $result->set($this->get('token_key'), $lastKey); } // Closure for getting the name of an object or prefix $getName = function ($object) { return isset($object['Key']) ? $object['Key'] : $object['Prefix']; }; // If common prefixes returned (i.e. a delimiter was set) and they need to be returned, there is more to do if ($this->get('return_prefixes') && $result->hasKey('CommonPrefixes')) { // Collect and format the prefixes to include with the objects $objects = array_merge($objects, $result->get('CommonPrefixes')); // Sort the objects and prefixes to maintain alphabetical order, but only if some of each were returned if ($this->get('sort_results') && $lastKey && $objects) { usort($objects, function ($object1, $object2) use ($getName) { return strcmp($getName($object1), $getName($object2)); }); } } // If only the names are desired, iterate through the results and convert the arrays to the object/prefix names if ($this->get('names_only')) { $objects = array_map($getName, $objects); } return $objects; } } sdk-2.5.2/Aws/S3/Iterator/ListObjectVersionsIterator.php000064411532700161006750000000303512272324173020236 0ustar get('Versions') ?: array(); $deleteMarkers = $result->get('DeleteMarkers') ?: array(); $versions = array_merge($versions, $deleteMarkers); // If there are prefixes and we want them, merge them in if ($this->get('return_prefixes') && $result->hasKey('CommonPrefixes')) { $versions = array_merge($versions, $result->get('CommonPrefixes')); } return $versions; } } sdk-2.5.2/Aws/S3/Iterator/OpendirIterator.php000064411532700161006750000000406612272324173016050 0ustar filePrefix = $filePrefix; $this->dirHandle = $dirHandle; $this->next(); } public function __destruct() { if ($this->dirHandle) { closedir($this->dirHandle); } } public function rewind() { $this->key = 0; rewinddir($this->dirHandle); } public function current() { return $this->currentFile; } public function next() { if ($file = readdir($this->dirHandle)) { $this->currentFile = new \SplFileInfo($this->filePrefix . $file); } else { $this->currentFile = false; } $this->key++; } public function key() { return $this->key; } public function valid() { return $this->currentFile !== false; } } sdk-2.5.2/Aws/S3/Model/Acp.php000064411532700161006750000001444712272324173012714 0ustar setOwner($owner); $this->setGrants($grants); } /** * Create an Acp object from an array. This can be used to create an ACP from a response to a GetObject/Bucket ACL * operation. * * @param array $data Array of ACP data * * @return self */ public static function fromArray(array $data) { $builder = new AcpBuilder(); $builder->setOwner((string) $data['Owner']['ID'], $data['Owner']['DisplayName']); // Add each Grantee to the ACP foreach ($data['Grants'] as $grant) { $permission = $grant['Permission']; // Determine the type for response bodies that are missing the Type parameter if (!isset($grant['Grantee']['Type'])) { if (isset($grant['Grantee']['ID'])) { $grant['Grantee']['Type'] = 'CanonicalUser'; } elseif (isset($grant['Grantee']['URI'])) { $grant['Grantee']['Type'] = 'Group'; } else { $grant['Grantee']['Type'] = 'AmazonCustomerByEmail'; } } switch ($grant['Grantee']['Type']) { case 'Group': $builder->addGrantForGroup($permission, $grant['Grantee']['URI']); break; case 'AmazonCustomerByEmail': $builder->addGrantForEmail($permission, $grant['Grantee']['EmailAddress']); break; case 'CanonicalUser': $builder->addGrantForUser( $permission, $grant['Grantee']['ID'], $grant['Grantee']['DisplayName'] ); } } return $builder->build(); } /** * Set the owner of the ACP policy * * @param Grantee $owner ACP policy owner * * @return self * * @throws InvalidArgumentException if the grantee does not have an ID set */ public function setOwner(Grantee $owner) { if (!$owner->isCanonicalUser()) { throw new InvalidArgumentException('The owner must have an ID set.'); } $this->owner = $owner; return $this; } /** * Get the owner of the ACP policy * * @return Grantee */ public function getOwner() { return $this->owner; } /** * Set the grants for the ACP * * @param array|\Traversable $grants List of grants for the ACP * * @return self * * @throws InvalidArgumentException */ public function setGrants($grants = array()) { $this->grants = new \SplObjectStorage(); if ($grants) { if (is_array($grants) || $grants instanceof \Traversable) { /** @var $grant Grant */ foreach ($grants as $grant) { $this->addGrant($grant); } } else { throw new InvalidArgumentException('Grants must be passed in as an array or Traversable object.'); } } return $this; } /** * Get all of the grants * * @return \SplObjectStorage */ public function getGrants() { return $this->grants; } /** * Add a Grant * * @param Grant $grant Grant to add * * @return self */ public function addGrant(Grant $grant) { if (count($this->grants) < 100) { $this->grants->attach($grant); } else { throw new OverflowException('An ACP may contain up to 100 grants.'); } return $this; } /** * Get the total number of attributes * * @return int */ public function count() { return count($this->grants); } /** * Returns the grants for iteration * * @return \SplObjectStorage */ public function getIterator() { return $this->grants; } /** * Applies grant headers to a command's parameters * * @param AbstractCommand $command Command to be updated * * @return self */ public function updateCommand(AbstractCommand $command) { $parameters = array(); foreach ($this->grants as $grant) { /** @var $grant Grant */ $parameters = array_merge_recursive($parameters, $grant->getParameterArray()); } foreach ($parameters as $name => $values) { $command->set($name, implode(', ', (array) $values)); } return $this; } /** * {@inheritdoc} */ public function toArray() { $grants = array(); foreach ($this->grants as $grant) { $grants[] = $grant->toArray(); } return array( 'Owner' => array( 'ID' => $this->owner->getId(), 'DisplayName' => $this->owner->getDisplayName() ), 'Grants' => $grants ); } } sdk-2.5.2/Aws/S3/Model/AcpBuilder.php000064411532700161006750000000650612272324173014220 0ustar owner = new Grantee($id, $displayName ?: $id, GranteeType::USER); return $this; } /** * Create and store a Grant with a CanonicalUser Grantee for the ACL * * @param string $permission Permission for the Grant * @param string $id Grantee identifier * @param string $displayName Grantee display name * * @return self */ public function addGrantForUser($permission, $id, $displayName = null) { $grantee = new Grantee($id, $displayName ?: $id, GranteeType::USER); $this->addGrant($permission, $grantee); return $this; } /** * Create and store a Grant with a AmazonCustomerByEmail Grantee for the ACL * * @param string $permission Permission for the Grant * @param string $email Grantee email address * * @return self */ public function addGrantForEmail($permission, $email) { $grantee = new Grantee($email, null, GranteeType::EMAIL); $this->addGrant($permission, $grantee); return $this; } /** * Create and store a Grant with a Group Grantee for the ACL * * @param string $permission Permission for the Grant * @param string $group Grantee group * * @return self */ public function addGrantForGroup($permission, $group) { $grantee = new Grantee($group, null, GranteeType::GROUP); $this->addGrant($permission, $grantee); return $this; } /** * Create and store a Grant for the ACL * * @param string $permission Permission for the Grant * @param Grantee $grantee The Grantee for the Grant * * @return self */ public function addGrant($permission, Grantee $grantee) { $this->grants[] = new Grant($grantee, $permission); return $this; } /** * Builds the ACP and returns it * * @return Acp */ public function build() { return new Acp($this->owner, $this->grants); } } sdk-2.5.2/Aws/S3/Model/ClearBucket.php000064411532700161006750000001265212272324173014371 0ustar client = $client; $this->bucket = $bucket; } /** * {@inheritdoc} */ public static function getAllEvents() { return array(self::AFTER_DELETE, self::BEFORE_CLEAR, self::AFTER_CLEAR); } /** * Set the bucket that is to be cleared * * @param string $bucket Name of the bucket to clear * * @return self */ public function setBucket($bucket) { $this->bucket = $bucket; return $this; } /** * Get the iterator used to yield the keys to be deleted. A default iterator * will be created and returned if no iterator has been explicitly set. * * @return \Iterator */ public function getIterator() { if (!$this->iterator) { $this->iterator = $this->client->getIterator('ListObjectVersions', array( 'Bucket' => $this->bucket )); } return $this->iterator; } /** * Sets a different iterator to use than the default iterator. This can be helpful when you wish to delete * only specific keys from a bucket (e.g. keys that match a certain prefix or delimiter, or perhaps keys that * pass through a filtered, decorated iterator). * * @param \Iterator $iterator Iterator used to yield the keys to be deleted * * @return self */ public function setIterator(\Iterator $iterator) { $this->iterator = $iterator; return $this; } /** * Set the MFA token to send with each request * * @param string $mfa MFA token to send with each request. The value is the concatenation of the authentication * device's serial number, a space, and the value displayed on your authentication device. * * @return self */ public function setMfa($mfa) { $this->mfa = $mfa; return $this; } /** * Clear the bucket * * @return int Returns the number of deleted keys * @throws ExceptionCollection */ public function clear() { $that = $this; $batch = DeleteObjectsBatch::factory($this->client, $this->bucket, $this->mfa); $batch = new NotifyingBatch($batch, function ($items) use ($that) { $that->dispatch(ClearBucket::AFTER_DELETE, array('keys' => $items)); }); $batch = new FlushingBatch(new ExceptionBufferingBatch($batch), 1000); // Let any listeners know that the bucket is about to be cleared $this->dispatch(self::BEFORE_CLEAR, array( 'iterator' => $this->getIterator(), 'batch' => $batch, 'mfa' => $this->mfa )); $deleted = 0; foreach ($this->getIterator() as $object) { if (isset($object['VersionId'])) { $versionId = $object['VersionId'] == 'null' ? null : $object['VersionId']; } else { $versionId = null; } $batch->addKey($object['Key'], $versionId); $deleted++; } $batch->flush(); // If any errors were encountered, then throw an ExceptionCollection if (count($batch->getExceptions())) { $e = new ExceptionCollection(); foreach ($batch->getExceptions() as $exception) { $e->add($exception->getPrevious()); } throw $e; } // Let any listeners know that the bucket was cleared $this->dispatch(self::AFTER_CLEAR, array('deleted' => $deleted)); return $deleted; } } sdk-2.5.2/Aws/S3/Model/DeleteObjectsBatch.php000064411532700161006750000000534312272324173015662 0ustar %s, VersionId => %s] and call flush when the objects * should be deleted. */ class DeleteObjectsBatch extends AbstractBatchDecorator { /** * Factory for creating a DeleteObjectsBatch * * @param AwsClientInterface $client Client used to transfer requests * @param string $bucket Bucket that contains the objects to delete * @param string $mfa MFA token to use with the request * * @return self */ public static function factory(AwsClientInterface $client, $bucket, $mfa = null) { $batch = BatchBuilder::factory() ->createBatchesWith(new BatchSizeDivisor(1000)) ->transferWith(new DeleteObjectsTransfer($client, $bucket, $mfa)) ->build(); return new self($batch); } /** * Add an object to be deleted * * @param string $key Key of the object * @param string $versionId VersionID of the object * * @return self */ public function addKey($key, $versionId = null) { return $this->add(array( 'Key' => $key, 'VersionId' => $versionId )); } /** * {@inheritdoc} */ public function add($item) { if ($item instanceof AbstractCommand && $item->getName() == 'DeleteObject') { $item = array( 'Key' => $item['Key'], 'VersionId' => $item['VersionId'] ); } if (!is_array($item) || (!isset($item['Key']))) { throw new InvalidArgumentException('Item must be a DeleteObject command or array containing a Key and VersionId key.'); } return $this->decoratedBatch->add($item); } } sdk-2.5.2/Aws/S3/Model/DeleteObjectsTransfer.php000064411532700161006750000000756512272324173016435 0ustar client = $client; $this->bucket = $bucket; $this->mfa = $mfa; } /** * Set a new MFA token value * * @param string $token MFA token * * @return self */ public function setMfa($token) { $this->mfa = $token; return $this; } /** * {@inheritdoc} * @throws OverflowException if a batch has more than 1000 items * @throws InvalidArgumentException when an invalid batch item is encountered */ public function transfer(array $batch) { if (empty($batch)) { return; } if (count($batch) > 1000) { throw new OverflowException('Batches should be divided into chunks of no larger than 1000 keys'); } $del = array(); $command = $this->client->getCommand('DeleteObjects', array( 'Bucket' => $this->bucket, Ua::OPTION => Ua::BATCH )); if ($this->mfa) { $command->getRequestHeaders()->set('x-amz-mfa', $this->mfa); } foreach ($batch as $object) { // Ensure that the batch item is valid if (!is_array($object) || !isset($object['Key'])) { throw new InvalidArgumentException('Invalid batch item encountered: ' . var_export($batch, true)); } $del[] = array( 'Key' => $object['Key'], 'VersionId' => isset($object['VersionId']) ? $object['VersionId'] : null ); } $command['Objects'] = $del; $command->execute(); $this->processResponse($command); } /** * Process the response of the DeleteMultipleObjects request * * @paramCommandInterface $command Command executed */ protected function processResponse(CommandInterface $command) { $result = $command->getResult(); // Ensure that the objects were deleted successfully if (!empty($result['Errors'])) { $errors = $result['Errors']; throw new DeleteMultipleObjectsException($errors); } } } sdk-2.5.2/Aws/S3/Model/Grant.php000064411532700161006750000000645712272324173013266 0ustar 'GrantRead', Permission::WRITE => 'GrantWrite', Permission::READ_ACP => 'GrantReadACP', Permission::WRITE_ACP => 'GrantWriteACP', Permission::FULL_CONTROL => 'GrantFullControl' ); /** * @var Grantee The grantee affected by the grant */ protected $grantee; /** * @var string The permission set by the grant */ protected $permission; /** * Constructs an ACL * * @param Grantee $grantee Affected grantee * @param string $permission Permission applied */ public function __construct(Grantee $grantee, $permission) { $this->setGrantee($grantee); $this->setPermission($permission); } /** * Set the grantee affected by the grant * * @param Grantee $grantee Affected grantee * * @return self */ public function setGrantee(Grantee $grantee) { $this->grantee = $grantee; return $this; } /** * Get the grantee affected by the grant * * @return Grantee */ public function getGrantee() { return $this->grantee; } /** * Set the permission set by the grant * * @param string $permission Permission applied * * @return self * * @throws InvalidArgumentException */ public function setPermission($permission) { $valid = Permission::values(); if (!in_array($permission, $valid)) { throw new InvalidArgumentException('The permission must be one of ' . 'the following: ' . implode(', ', $valid) . '.'); } $this->permission = $permission; return $this; } /** * Get the permission set by the grant * * @return string */ public function getPermission() { return $this->permission; } /** * Returns an array of the operation parameter and value to set on the operation * * @return array */ public function getParameterArray() { return array( self::$parameterMap[$this->permission] => $this->grantee->getHeaderValue() ); } /** * {@inheritdoc} */ public function toArray() { return array( 'Grantee' => $this->grantee->toArray(), 'Permission' => $this->permission ); } } sdk-2.5.2/Aws/S3/Model/Grantee.php000064411532700161006750000001417612272324173013575 0ustar 'id', GranteeType::EMAIL => 'emailAddress', GranteeType::GROUP => 'uri' ); /** * @var string The account ID, email, or URL identifying the grantee */ protected $id; /** * @var string The display name of the grantee */ protected $displayName; /** * @var string The type of the grantee (CanonicalUser or Group) */ protected $type; /** * Constructs a Grantee * * @param string $id Grantee identifier * @param string $displayName Grantee display name * @param string $expectedType The expected type of the grantee */ public function __construct($id, $displayName = null, $expectedType = null) { $this->type = GranteeType::USER; $this->setId($id, $expectedType); $this->setDisplayName($displayName); } /** * Sets the account ID, email, or URL identifying the grantee * * @param string $id Grantee identifier * @param string $expectedType The expected type of the grantee * * @return Grantee * * @throws UnexpectedValueException if $expectedType is set and the grantee * is not of that type after instantiation * @throws InvalidArgumentException when the ID provided is not a string */ public function setId($id, $expectedType = null) { if (in_array($id, Group::values())) { $this->type = GranteeType::GROUP; } elseif (!is_string($id)) { throw new InvalidArgumentException('The grantee ID must be provided as a string value.'); } if (strpos($id, '@') !== false) { $this->type = GranteeType::EMAIL; } if ($expectedType && $expectedType !== $this->type) { throw new UnexpectedValueException('The type of the grantee after ' . 'setting the ID did not match the specified, expected type "' . $expectedType . '" but received "' . $this->type . '".'); } $this->id = $id; return $this; } /** * Gets the grantee identifier * * @return string */ public function getId() { return $this->id; } /** * Gets the grantee email address (if it is set) * * @return null|string */ public function getEmailAddress() { return $this->isAmazonCustomerByEmail() ? $this->id : null; } /** * Gets the grantee URI (if it is set) * * @return null|string */ public function getGroupUri() { return $this->isGroup() ? $this->id : null; } /** * Sets the display name of the grantee * * @param string $displayName Grantee name * * @return Grantee * * @throws LogicException when the grantee type not CanonicalUser */ public function setDisplayName($displayName) { if ($this->type === GranteeType::USER) { if (empty($displayName) || !is_string($displayName)) { $displayName = $this->id; } $this->displayName = $displayName; } else { if ($displayName) { throw new LogicException('The display name can only be set ' . 'for grantees specified by ID.'); } } return $this; } /** * Gets the grantee display name * * @return string */ public function getDisplayName() { return $this->displayName; } /** * Gets the grantee type (determined by ID) * * @return string */ public function getType() { return $this->type; } /** * Returns true if this grantee object represents a canonical user by ID * * @return bool */ public function isCanonicalUser() { return ($this->type === GranteeType::USER); } /** * Returns true if this grantee object represents a customer by email * * @return bool */ public function isAmazonCustomerByEmail() { return ($this->type === GranteeType::EMAIL); } /** * Returns true if this grantee object represents a group by URL * * @return bool */ public function isGroup() { return ($this->type === GranteeType::GROUP); } /** * Returns the value used in headers to specify this grantee * * @return string */ public function getHeaderValue() { $key = self::$headerMap[$this->type]; return "{$key}=\"{$this->id}\""; } /** * {@inheritdoc} */ public function toArray() { $result = array( 'Type' => $this->type ); switch ($this->type) { case GranteeType::USER: $result['ID'] = $this->id; $result['DisplayName'] = $this->displayName; break; case GranteeType::EMAIL: $result['EmailAddress'] = $this->id; break; case GranteeType::GROUP: $result['URI'] = $this->id; } return $result; } } sdk-2.5.2/Aws/S3/Model/PostObject.php000064411532700161006750000001712612272324173014262 0ustar tag attributes as an array */ protected $formAttributes; /** * @var array The form's elements as an array */ protected $formInputs; /** * @var string The raw json policy */ protected $jsonPolicy; /** * Constructs the PostObject * * The options array accepts the following keys: * * - acl: The access control setting to apply to the uploaded file. Accepts any of the * CannedAcl constants * - Cache-Control: The Cache-Control HTTP header value to apply to the uploaded file * - Content-Disposition: The Content-Disposition HTTP header value to apply to the uploaded file * - Content-Encoding: The Content-Encoding HTTP header value to apply to the uploaded file * - Content-Type: The Content-Type HTTP header value to apply to the uploaded file. The default * value is `application/octet-stream` * - Expires: The Expires HTTP header value to apply to the uploaded file * - key: The location where the file should be uploaded to. The default value is * `^${filename}` which will use the name of the uploaded file * - policy: A raw policy in JSON format. By default, the PostObject creates one for you * - success_action_redirect: The URI for Amazon S3 to redirect to upon successful upload * - success_action_status: The status code for Amazon S3 to return upon successful upload * - ttd: The expiration time for the generated upload form data * - x-amz-server-side-encryption: The server-side encryption mechanism to use * - x-amz-storage-class: The storage setting to apply to the object * - x-amz-meta-*: Any custom meta tag that should be set to the object * * For the Cache-Control, Content-Disposition, Content-Encoding, * Content-Type, Expires, and key options, to use a "starts-with" comparison * instead of an equals comparison, prefix the value with a ^ (carat) * character * * @param S3Client $client * @param $bucket * @param array $options */ public function __construct(S3Client $client, $bucket, array $options = array()) { $this->setClient($client); $this->setBucket($bucket); parent::__construct($options); } /** * Analyzes the provided data and turns it into useful data that can be * consumed and used to build an upload form * * @return PostObject */ public function prepareData() { // Validate required options $options = Collection::fromConfig($this->data, array( 'ttd' => '+1 hour', 'key' => '^${filename}', )); // Format ttd option $ttd = $options['ttd']; $ttd = is_numeric($ttd) ? (int) $ttd : strtotime($ttd); unset($options['ttd']); // Save policy if passed in $rawPolicy = $options['policy']; unset($options['policy']); // Setup policy document $policy = array( 'expiration' => gmdate(DateFormat::ISO8601_S3, $ttd), 'conditions' => array(array('bucket' => $this->bucket)) ); // Configure the endpoint/action $url = Url::factory($this->client->getBaseUrl()); $url->setHost($this->bucket . '.' . $url->getHost()); // Setup basic form $this->formAttributes = array( 'action' => (string) $url, 'method' => 'POST', 'enctype' => 'multipart/form-data' ); $this->formInputs = array( 'AWSAccessKeyId' => $this->client->getCredentials()->getAccessKeyId() ); // Add success action status $status = (int) $options->get('success_action_status'); if ($status && in_array($status, array(200, 201, 204))) { $this->formInputs['success_action_status'] = (string) $status; $policy['conditions'][] = array( 'success_action_status' => (string) $status ); $options->remove('success_action_status'); } // Add other options foreach ($options as $key => $value) { $value = (string) $value; if ($value[0] === '^') { $value = substr($value, 1); $this->formInputs[$key] = $value; $value = preg_replace('/\$\{(\w*)\}/', '', $value); $policy['conditions'][] = array('starts-with', '$' . $key, $value); } else { $this->formInputs[$key] = $value; $policy['conditions'][] = array($key => $value); } } // Add policy $this->jsonPolicy = $rawPolicy ?: json_encode($policy); $jsonPolicy64 = base64_encode($this->jsonPolicy); $this->formInputs['policy'] = $jsonPolicy64; // Add signature $this->formInputs['signature'] = base64_encode(hash_hmac( 'sha1', $jsonPolicy64, $this->client->getCredentials()->getSecretKey(), true )); return $this; } /** * Sets the S3 client * * @param S3Client $client * * @return PostObject */ public function setClient(S3Client $client) { $this->client = $client; return $this; } /** * Gets the S3 client * * @return S3Client */ public function getClient() { return $this->client; } /** * Sets the bucket and makes sure it is a valid bucket name * * @param string $bucket * * @return PostObject */ public function setBucket($bucket) { $this->bucket = $bucket; return $this; } /** * Gets the bucket name * * @return string */ public function getBucket() { return $this->bucket; } /** * Gets the form attributes as an array * * @return array */ public function getFormAttributes() { return $this->formAttributes; } /** * Gets the form inputs as an array * * @return array */ public function getFormInputs() { return $this->formInputs; } /** * Gets the raw JSON policy * * @return string */ public function getJsonPolicy() { return $this->jsonPolicy; } } sdk-2.5.2/Aws/S3/Model/MultipartUpload/AbstractTransfer.php000064411532700161006750000000641512272324173020603 0ustar options = array_replace(array( 'min_part_size' => self::MIN_PART_SIZE, 'part_md5' => true ), $this->options); // Make sure the part size can be calculated somehow if (!$this->options['min_part_size'] && !$this->source->getContentLength()) { throw new RuntimeException('The ContentLength of the data source could not be determined, and no ' . 'min_part_size option was provided'); } } /** * {@inheritdoc} */ protected function calculatePartSize() { $partSize = $this->source->getContentLength() ? (int) ceil(($this->source->getContentLength() / self::MAX_PARTS)) : self::MIN_PART_SIZE; $partSize = max($this->options['min_part_size'], $partSize); $partSize = min($partSize, self::MAX_PART_SIZE); $partSize = max($partSize, self::MIN_PART_SIZE); return $partSize; } /** * {@inheritdoc} */ protected function complete() { /** @var $part UploadPart */ $parts = array(); foreach ($this->state as $part) { $parts[] = array( 'PartNumber' => $part->getPartNumber(), 'ETag' => $part->getETag(), ); } $params = $this->state->getUploadId()->toParams(); $params[Ua::OPTION] = Ua::MULTIPART_UPLOAD; $params['Parts'] = $parts; $command = $this->client->getCommand('CompleteMultipartUpload', $params); return $command->getResult(); } /** * {@inheritdoc} */ protected function getAbortCommand() { $params = $this->state->getUploadId()->toParams(); $params[Ua::OPTION] = Ua::MULTIPART_UPLOAD; /** @var $command OperationCommand */ $command = $this->client->getCommand('AbortMultipartUpload', $params); return $command; } } sdk-2.5.2/Aws/S3/Model/MultipartUpload/ParallelTransfer.php000064411532700161006750000001101612272324173020565 0ustar source->isLocal() || $this->source->getWrapper() != 'plainfile') { throw new RuntimeException('The source data must be a local file stream when uploading in parallel.'); } if (empty($this->options['concurrency'])) { throw new RuntimeException('The `concurrency` option must be specified when instantiating.'); } } /** * {@inheritdoc} */ protected function transfer() { $totalParts = (int) ceil($this->source->getContentLength() / $this->partSize); $concurrency = min($totalParts, $this->options['concurrency']); $partsToSend = $this->prepareParts($concurrency); $eventData = $this->getEventData(); while (!$this->stopped && count($this->state) < $totalParts) { $currentTotal = count($this->state); $commands = array(); for ($i = 0; $i < $concurrency && $i + $currentTotal < $totalParts; $i++) { // Move the offset to the correct position $partsToSend[$i]->setOffset(($currentTotal + $i) * $this->partSize); // @codeCoverageIgnoreStart if ($partsToSend[$i]->getContentLength() == 0) { break; } // @codeCoverageIgnoreEnd $params = $this->state->getUploadId()->toParams(); $eventData['command'] = $this->client->getCommand('UploadPart', array_replace($params, array( 'PartNumber' => count($this->state) + 1 + $i, 'Body' => $partsToSend[$i], 'ContentMD5' => (bool) $this->options['part_md5'], Ua::OPTION => Ua::MULTIPART_UPLOAD ))); $commands[] = $eventData['command']; // Notify any listeners of the part upload $this->dispatch(self::BEFORE_PART_UPLOAD, $eventData); } // Allow listeners to stop the transfer if needed if ($this->stopped) { break; } // Execute each command, iterate over the results, and add to the transfer state /** @var $command \Guzzle\Service\Command\OperationCommand */ foreach ($this->client->execute($commands) as $command) { $this->state->addPart(UploadPart::fromArray(array( 'PartNumber' => count($this->state) + 1, 'ETag' => $command->getResponse()->getEtag(), 'Size' => (int) $command->getResponse()->getContentLength(), 'LastModified' => gmdate(DateFormat::RFC2822) ))); $eventData['command'] = $command; // Notify any listeners the the part was uploaded $this->dispatch(self::AFTER_PART_UPLOAD, $eventData); } } } /** * Prepare the entity body handles to use while transferring * * @param int $concurrency Number of parts to prepare * * @return array Parts to send */ protected function prepareParts($concurrency) { $url = $this->source->getUri(); // Use the source EntityBody as the first part $parts = array(new ReadLimitEntityBody($this->source, $this->partSize)); // Open EntityBody handles for each part to upload in parallel for ($i = 1; $i < $concurrency; $i++) { $parts[] = new ReadLimitEntityBody(new EntityBody(fopen($url, 'r')), $this->partSize); } return $parts; } } sdk-2.5.2/Aws/S3/Model/MultipartUpload/SerialTransfer.php000064411532700161006750000000616512272324173020261 0ustar stopped && !$this->source->isConsumed()) { if ($this->source->getContentLength() && $this->source->isSeekable()) { // If the stream is seekable and the Content-Length known, then stream from the data source $body = new ReadLimitEntityBody($this->source, $this->partSize, $this->source->ftell()); } else { // We need to read the data source into a temporary buffer before streaming $body = EntityBody::factory(); while ($body->getContentLength() < $this->partSize && $body->write( $this->source->read(max(1, min(10 * Size::KB, $this->partSize - $body->getContentLength()))) )); } // @codeCoverageIgnoreStart if ($body->getContentLength() == 0) { break; } // @codeCoverageIgnoreEnd $params = $this->state->getUploadId()->toParams(); $command = $this->client->getCommand('UploadPart', array_replace($params, array( 'PartNumber' => count($this->state) + 1, 'Body' => $body, 'ContentMD5' => (bool) $this->options['part_md5'], Ua::OPTION => Ua::MULTIPART_UPLOAD ))); // Notify observers that the part is about to be uploaded $eventData = $this->getEventData(); $eventData['command'] = $command; $this->dispatch(self::BEFORE_PART_UPLOAD, $eventData); // Allow listeners to stop the transfer if needed if ($this->stopped) { break; } $response = $command->getResponse(); $this->state->addPart(UploadPart::fromArray(array( 'PartNumber' => count($this->state) + 1, 'ETag' => $response->getEtag(), 'Size' => $body->getContentLength(), 'LastModified' => gmdate(DateFormat::RFC2822) ))); // Notify observers that the part was uploaded $this->dispatch(self::AFTER_PART_UPLOAD, $eventData); } } } sdk-2.5.2/Aws/S3/Model/MultipartUpload/TransferState.php000064411532700161006750000000237112272324173020115 0ustar getIterator('ListParts', $uploadId->toParams()) as $part) { $transferState->addPart(UploadPart::fromArray($part)); } return $transferState; } } sdk-2.5.2/Aws/S3/Model/MultipartUpload/UploadBuilder.php000064411532700161006750000002056412272324173020067 0ustar setOption('Bucket', $bucket); } /** * Set the key of the object * * @param string $key Key of the object to upload * * @return self */ public function setKey($key) { return $this->setOption('Key', $key); } /** * Set the minimum acceptable part size * * @param int $minSize Minimum acceptable part size in bytes * * @return self */ public function setMinPartSize($minSize) { $this->minPartSize = (int) max((int) $minSize, AbstractTransfer::MIN_PART_SIZE); return $this; } /** * Set the concurrency level to use when uploading parts. This affects how * many parts are uploaded in parallel. You must use a local file as your * data source when using a concurrency greater than 1 * * @param int $concurrency Concurrency level * * @return self */ public function setConcurrency($concurrency) { $this->concurrency = $concurrency; return $this; } /** * Explicitly set the MD5 hash of the entire body * * @param string $md5 MD5 hash of the entire body * * @return self */ public function setMd5($md5) { $this->md5 = $md5; return $this; } /** * Set to true to have the builder calculate the MD5 hash of the entire data * source before initiating a multipart upload (this could be an expensive * operation). This setting can ony be used with seekable data sources. * * @param bool $calculateMd5 Set to true to calculate the MD5 hash of the body * * @return self */ public function calculateMd5($calculateMd5) { $this->calculateEntireMd5 = (bool) $calculateMd5; return $this; } /** * Specify whether or not to calculate the MD5 hash of each uploaded part. * This setting defaults to true. * * @param bool $usePartMd5 Set to true to calculate the MD5 has of each part * * @return self */ public function calculatePartMd5($usePartMd5) { $this->calculatePartMd5 = (bool) $usePartMd5; return $this; } /** * Set the ACP to use on the object * * @param Acp $acp ACP to set on the object * * @return self */ public function setAcp(Acp $acp) { return $this->setOption('ACP', $acp); } /** * Set an option to pass to the initial CreateMultipartUpload operation * * @param string $name Option name * @param string $value Option value * * @return self */ public function setOption($name, $value) { $this->commandOptions[$name] = $value; return $this; } /** * Add an array of options to pass to the initial CreateMultipartUpload operation * * @param array $options Array of CreateMultipartUpload operation parameters * * @return self */ public function addOptions(array $options) { $this->commandOptions = array_replace($this->commandOptions, $options); return $this; } /** * Set an array of transfer options to apply to the upload transfer object * * @param array $options Transfer options * * @return self */ public function setTransferOptions(array $options) { $this->transferOptions = $options; return $this; } /** * {@inheritdoc} * @throws InvalidArgumentException when attempting to resume a transfer using a non-seekable stream * @throws InvalidArgumentException when missing required properties (bucket, key, client, source) */ public function build() { if ($this->state instanceof TransferState) { $this->commandOptions = array_replace($this->commandOptions, $this->state->getUploadId()->toParams()); } if (!isset($this->commandOptions['Bucket']) || !isset($this->commandOptions['Key']) || !$this->client || !$this->source ) { throw new InvalidArgumentException('You must specify a Bucket, Key, client, and source.'); } if ($this->state && !$this->source->isSeekable()) { throw new InvalidArgumentException('You cannot resume a transfer using a non-seekable source.'); } // If no state was set, then create one by initiating or loading a multipart upload if (is_string($this->state)) { $this->state = TransferState::fromUploadId($this->client, UploadId::fromParams(array( 'Bucket' => $this->commandOptions['Bucket'], 'Key' => $this->commandOptions['Key'], 'UploadId' => $this->state ))); } elseif (!$this->state) { $this->state = $this->initiateMultipartUpload(); } $options = array_replace(array( 'min_part_size' => $this->minPartSize, 'part_md5' => (bool) $this->calculatePartMd5, 'concurrency' => $this->concurrency ), $this->transferOptions); return $this->concurrency > 1 ? new ParallelTransfer($this->client, $this->state, $this->source, $options) : new SerialTransfer($this->client, $this->state, $this->source, $options); } /** * {@inheritdoc} */ protected function initiateMultipartUpload() { // Determine Content-Type if ($mimeType = $this->source->getContentType()) { $this->commandOptions['ContentType'] = $mimeType; } $params = array_replace(array( Ua::OPTION => Ua::MULTIPART_UPLOAD, 'command.headers' => $this->headers, 'Metadata' => array() ), $this->commandOptions); // Calculate the MD5 hash if none was set and it is asked of the builder if ($this->calculateEntireMd5) { $this->md5 = $this->source->getContentMd5(); } // If an MD5 is specified, then add it to the custom headers of the request // so that it will be returned when downloading the object from Amazon S3 if ($this->md5) { $params['Metadata']['x-amz-Content-MD5'] = $this->md5; } $result = $this->client->getCommand('CreateMultipartUpload', $params)->execute(); // Create a new state based on the initiated upload $params['UploadId'] = $result['UploadId']; return new TransferState(UploadId::fromParams($params)); } } sdk-2.5.2/Aws/S3/Model/MultipartUpload/UploadId.php000064411532700161006750000000177012272324173017033 0ustar false, 'Key' => false, 'UploadId' => false ); } sdk-2.5.2/Aws/S3/Model/MultipartUpload/UploadPart.php000064411532700161006750000000320412272324173017377 0ustar 'partNumber', 'ETag' => 'eTag', 'LastModified' => 'lastModified', 'Size' => 'size' ); /** * @var string The ETag for this part */ protected $eTag; /** * @var string The last modified date */ protected $lastModified; /** * @var int The size (or content-length) in bytes of the upload body */ protected $size; /** * @return string */ public function getETag() { return $this->eTag; } /** * @return string */ public function getLastModified() { return $this->lastModified; } /** * @return int */ public function getSize() { return $this->size; } } sdk-2.5.2/Aws/S3/Resources/s3-2006-03-01.php000064411532700161006750000047407212272324173014477 0ustar '2006-03-01', 'endpointPrefix' => 's3', 'serviceFullName' => 'Amazon Simple Storage Service', 'serviceAbbreviation' => 'Amazon S3', 'serviceType' => 'rest-xml', 'timestampFormat' => 'rfc822', 'globalEndpoint' => 's3.amazonaws.com', 'signatureVersion' => 's3', 'namespace' => 'S3', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 's3-us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 's3-ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AbortMultipartUpload' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'AbortMultipartUploadOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadAbort.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), ), 'errorResponses' => array( array( 'reason' => 'The specified multipart upload does not exist.', 'class' => 'NoSuchUploadException', ), ), ), 'CompleteMultipartUpload' => array( 'httpMethod' => 'POST', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'CompleteMultipartUploadOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadComplete.html', 'data' => array( 'xmlRoot' => array( 'name' => 'CompleteMultipartUpload', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Parts' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Part', 'properties' => array( 'ETag' => array( 'type' => 'string', ), 'PartNumber' => array( 'type' => 'numeric', ), ), ), ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'CopyObject' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'CopyObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectCOPY.html', 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'CopySource' => array( 'required' => true, 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source', ), 'CopySourceIfMatch' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-match', ), 'CopySourceIfModifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-modified-since', ), 'CopySourceIfNoneMatch' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-none-match', ), 'CopySourceIfUnmodifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-unmodified-since', ), 'Expires' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'MetadataDirective' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-metadata-directive', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'StorageClass' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-storage-class', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The source object of the COPY operation is not in the active tier and is only stored in Amazon Glacier.', 'class' => 'ObjectNotInActiveTierErrorException', ), ), ), 'CreateBucket' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'CreateBucketOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUT.html', 'data' => array( 'xmlRoot' => array( 'name' => 'CreateBucketConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'LocationConstraint' => array( 'type' => 'string', 'location' => 'xml', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWrite' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), ), 'errorResponses' => array( array( 'reason' => 'The requested bucket name is not available. The bucket namespace is shared by all users of the system. Please select a different name and try again.', 'class' => 'BucketAlreadyExistsException', ), ), ), 'CreateMultipartUpload' => array( 'httpMethod' => 'POST', 'uri' => '/{Bucket}{/Key*}?uploads', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'CreateMultipartUploadOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadInitiate.html', 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'Expires' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'StorageClass' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-storage-class', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'DeleteBucket' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETE.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketCors' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?cors', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketCorsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEcors.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketLifecycle' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?lifecycle', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketLifecycleOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETElifecycle.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketPolicy' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?policy', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketPolicyOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEpolicy.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketTagging' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?tagging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketTaggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEtagging.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketWebsite' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?website', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketWebsiteOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEwebsite.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteObject' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectDELETE.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'MFA' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-mfa', ), 'VersionId' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'versionId', ), ), ), 'DeleteObjects' => array( 'httpMethod' => 'POST', 'uri' => '/{Bucket}?delete', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteObjectsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/multiobjectdeleteapi.html', 'data' => array( 'xmlRoot' => array( 'name' => 'Delete', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'contentMd5' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Objects' => array( 'required' => true, 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Object', 'properties' => array( 'Key' => array( 'required' => true, 'type' => 'string', ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'Quiet' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'MFA' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-mfa', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketAcl' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?acl', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketAclOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETacl.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketCors' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?cors', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketCorsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETcors.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketLifecycle' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?lifecycle', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketLifecycleOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETlifecycle.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketLocation' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?location', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketLocationOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETlocation.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'GetBucketLogging' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?logging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketLoggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETlogging.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketNotification' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?notification', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketNotificationOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETnotification.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketPolicy' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?policy', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketPolicyOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETpolicy.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'GetBucketRequestPayment' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?requestPayment', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketRequestPaymentOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTrequestPaymentGET.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketTagging' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?tagging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketTaggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETtagging.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketVersioning' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?versioning', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketVersioningOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETversioningStatus.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketWebsite' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?website', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketWebsiteOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETwebsite.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetObject' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectGET.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'IfModifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'If-Modified-Since', ), 'IfNoneMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-None-Match', ), 'IfUnmodifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'If-Unmodified-Since', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Range' => array( 'type' => 'string', 'location' => 'header', ), 'ResponseCacheControl' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-cache-control', ), 'ResponseContentDisposition' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-content-disposition', ), 'ResponseContentEncoding' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-content-encoding', ), 'ResponseContentLanguage' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-content-language', ), 'ResponseContentType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-content-type', ), 'ResponseExpires' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'query', 'sentAs' => 'response-expires', ), 'VersionId' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'versionId', ), 'SaveAs' => array( 'location' => 'response_body', ), ), 'errorResponses' => array( array( 'reason' => 'The specified key does not exist.', 'class' => 'NoSuchKeyException', ), ), ), 'GetObjectAcl' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}{/Key*}?acl', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetObjectAclOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectGETacl.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'VersionId' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'versionId', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified key does not exist.', 'class' => 'NoSuchKeyException', ), ), ), 'GetObjectTorrent' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}{/Key*}?torrent', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetObjectTorrentOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectGETtorrent.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), ), ), 'HeadBucket' => array( 'httpMethod' => 'HEAD', 'uri' => '/{Bucket}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'HeadBucketOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketHEAD.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'The specified bucket does not exist.', 'class' => 'NoSuchBucketException', ), ), ), 'HeadObject' => array( 'httpMethod' => 'HEAD', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'HeadObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectHEAD.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'IfModifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'If-Modified-Since', ), 'IfNoneMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-None-Match', ), 'IfUnmodifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'If-Unmodified-Since', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Range' => array( 'type' => 'string', 'location' => 'header', ), 'VersionId' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'versionId', ), ), 'errorResponses' => array( array( 'reason' => 'The specified key does not exist.', 'class' => 'NoSuchKeyException', ), ), ), 'ListBuckets' => array( 'httpMethod' => 'GET', 'uri' => '/', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListBucketsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTServiceGET.html', 'parameters' => array( 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'ListMultipartUploads' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?uploads', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListMultipartUploadsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadListMPUpload.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Delimiter' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'delimiter', ), 'EncodingType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'encoding-type', ), 'KeyMarker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'key-marker', ), 'MaxUploads' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'max-uploads', ), 'Prefix' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'prefix', ), 'UploadIdMarker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'upload-id-marker', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'ListObjectVersions' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?versions', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListObjectVersionsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETVersion.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Delimiter' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'delimiter', ), 'EncodingType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'encoding-type', ), 'KeyMarker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'key-marker', ), 'MaxKeys' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'max-keys', ), 'Prefix' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'prefix', ), 'VersionIdMarker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'version-id-marker', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'ListObjects' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListObjectsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGET.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Delimiter' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'delimiter', ), 'EncodingType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'encoding-type', ), 'Marker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'marker', ), 'MaxKeys' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'max-keys', ), 'Prefix' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'prefix', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified bucket does not exist.', 'class' => 'NoSuchBucketException', ), ), ), 'ListParts' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListPartsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadListParts.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'MaxParts' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'max-parts', ), 'PartNumberMarker' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'part-number-marker', ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'PutBucketAcl' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?acl', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketAclOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTacl.html', 'data' => array( 'xmlRoot' => array( 'name' => 'AccessControlPolicy', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Grants' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'AccessControlList', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWrite' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), ), ), 'PutBucketCors' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?cors', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketCorsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTcors.html', 'data' => array( 'xmlRoot' => array( 'name' => 'CORSConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'contentMd5' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CORSRules' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'CORSRule', 'properties' => array( 'AllowedHeaders' => array( 'type' => 'array', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedHeader', ), ), 'AllowedMethods' => array( 'type' => 'array', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedMethod', ), ), 'AllowedOrigins' => array( 'type' => 'array', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedOrigin', ), ), 'ExposeHeaders' => array( 'type' => 'array', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'ExposeHeader', ), ), 'MaxAgeSeconds' => array( 'type' => 'numeric', ), ), ), ), ), ), 'PutBucketLifecycle' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?lifecycle', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketLifecycleOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTlifecycle.html', 'data' => array( 'xmlRoot' => array( 'name' => 'LifecycleConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'contentMd5' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Rules' => array( 'required' => true, 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Rule', 'properties' => array( 'Expiration' => array( 'type' => 'object', 'properties' => array( 'Date' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', ), 'Days' => array( 'type' => 'numeric', ), ), ), 'ID' => array( 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), 'Status' => array( 'required' => true, 'type' => 'string', ), 'Transition' => array( 'type' => 'object', 'properties' => array( 'Date' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', ), 'Days' => array( 'type' => 'numeric', ), 'StorageClass' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'PutBucketLogging' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?logging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketLoggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTlogging.html', 'data' => array( 'xmlRoot' => array( 'name' => 'BucketLoggingStatus', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'xmlAllowEmpty' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'LoggingEnabled' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetBucket' => array( 'type' => 'string', ), 'TargetGrants' => array( 'type' => 'array', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'TargetPrefix' => array( 'type' => 'string', ), ), ), ), ), 'PutBucketNotification' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?notification', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketNotificationOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTnotification.html', 'data' => array( 'xmlRoot' => array( 'name' => 'NotificationConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'TopicConfiguration' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Event' => array( 'type' => 'string', ), 'Topic' => array( 'type' => 'string', ), ), ), ), ), 'PutBucketPolicy' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?policy', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketPolicyOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTpolicy.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Policy' => array( 'required' => true, 'type' => array( 'string', 'object', ), 'location' => 'body', ), ), ), 'PutBucketRequestPayment' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?requestPayment', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketRequestPaymentOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTrequestPaymentPUT.html', 'data' => array( 'xmlRoot' => array( 'name' => 'RequestPaymentConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Payer' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), ), ), 'PutBucketTagging' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?tagging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketTaggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTtagging.html', 'data' => array( 'xmlRoot' => array( 'name' => 'Tagging', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'contentMd5' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'TagSet' => array( 'required' => true, 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Tag', 'required' => true, 'type' => 'object', 'properties' => array( 'Key' => array( 'required' => true, 'type' => 'string', ), 'Value' => array( 'required' => true, 'type' => 'string', ), ), ), ), ), ), 'PutBucketVersioning' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?versioning', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketVersioningOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTVersioningStatus.html', 'data' => array( 'xmlRoot' => array( 'name' => 'VersioningConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'MFA' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-mfa', ), 'MFADelete' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'PutBucketWebsite' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?website', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketWebsiteOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTwebsite.html', 'data' => array( 'xmlRoot' => array( 'name' => 'WebsiteConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'xmlAllowEmpty' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'ErrorDocument' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Key' => array( 'required' => true, 'type' => 'string', ), ), ), 'IndexDocument' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Suffix' => array( 'required' => true, 'type' => 'string', ), ), ), 'RedirectAllRequestsTo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'HostName' => array( 'required' => true, 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), ), ), 'RoutingRules' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'RoutingRule', 'type' => 'object', 'properties' => array( 'Condition' => array( 'type' => 'object', 'properties' => array( 'HttpErrorCodeReturnedEquals' => array( 'type' => 'string', ), 'KeyPrefixEquals' => array( 'type' => 'string', ), ), ), 'Redirect' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'HostName' => array( 'type' => 'string', ), 'HttpRedirectCode' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), 'ReplaceKeyPrefixWith' => array( 'type' => 'string', ), 'ReplaceKeyWith' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'PutObject' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectPUT.html', 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Body' => array( 'type' => array( 'string', 'object', ), 'location' => 'body', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentLength' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'Content-Length', ), 'ContentMD5' => array( 'type' => array( 'string', 'boolean', ), 'location' => 'header', 'sentAs' => 'Content-MD5', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'Expires' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'StorageClass' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-storage-class', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), ), ), 'PutObjectAcl' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}?acl', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutObjectAclOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectPUTacl.html', 'data' => array( 'xmlRoot' => array( 'name' => 'AccessControlPolicy', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Grants' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'AccessControlList', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWrite' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), ), 'errorResponses' => array( array( 'reason' => 'The specified key does not exist.', 'class' => 'NoSuchKeyException', ), ), ), 'RestoreObject' => array( 'httpMethod' => 'POST', 'uri' => '/{Bucket}{/Key*}?restore', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'RestoreObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectRestore.html', 'data' => array( 'xmlRoot' => array( 'name' => 'RestoreRequest', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Days' => array( 'required' => true, 'type' => 'numeric', 'location' => 'xml', ), ), 'errorResponses' => array( array( 'reason' => 'This operation is not allowed against this storage tier', 'class' => 'ObjectAlreadyInActiveTierErrorException', ), ), ), 'UploadPart' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'UploadPartOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadUploadPart.html', 'parameters' => array( 'Body' => array( 'type' => array( 'string', 'object', ), 'location' => 'body', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'ContentLength' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'Content-Length', ), 'ContentMD5' => array( 'type' => array( 'string', 'boolean', ), 'location' => 'header', 'sentAs' => 'Content-MD5', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'PartNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'partNumber', ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), ), ), 'UploadPartCopy' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'UploadPartCopyOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadUploadPartCopy.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CopySource' => array( 'required' => true, 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source', ), 'CopySourceIfMatch' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-match', ), 'CopySourceIfModifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-modified-since', ), 'CopySourceIfNoneMatch' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-none-match', ), 'CopySourceIfUnmodifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-unmodified-since', ), 'CopySourceRange' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-range', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'PartNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'partNumber', ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), ), 'models' => array( 'AbortMultipartUploadOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CompleteMultipartUploadOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Bucket' => array( 'type' => 'string', 'location' => 'xml', ), 'ETag' => array( 'type' => 'string', 'location' => 'xml', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'Key' => array( 'type' => 'string', 'location' => 'xml', ), 'Location' => array( 'type' => 'string', 'location' => 'xml', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CopyObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ETag' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModified' => array( 'type' => 'string', 'location' => 'xml', ), 'CopySourceVersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-version-id', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateBucketOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateMultipartUploadOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Bucket' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'Bucket', ), 'Key' => array( 'type' => 'string', 'location' => 'xml', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'UploadId' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketCorsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketLifecycleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketPolicyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketTaggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketWebsiteOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DeleteMarker' => array( 'type' => 'boolean', 'location' => 'header', 'sentAs' => 'x-amz-delete-marker', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteObjectsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Deleted' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'DeleteMarker' => array( 'type' => 'boolean', ), 'DeleteMarkerVersionId' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'Errors' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Error', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Error', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketAclOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Grants' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'AccessControlList', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'sentAs' => 'Grant', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketCorsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CORSRules' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'CORSRule', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'CORSRule', 'properties' => array( 'AllowedHeaders' => array( 'type' => 'array', 'sentAs' => 'AllowedHeader', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedHeader', ), ), 'AllowedMethods' => array( 'type' => 'array', 'sentAs' => 'AllowedMethod', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedMethod', ), ), 'AllowedOrigins' => array( 'type' => 'array', 'sentAs' => 'AllowedOrigin', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedOrigin', ), ), 'ExposeHeaders' => array( 'type' => 'array', 'sentAs' => 'ExposeHeader', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'ExposeHeader', ), ), 'MaxAgeSeconds' => array( 'type' => 'numeric', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketLifecycleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Rules' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Rule', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Rule', 'properties' => array( 'Expiration' => array( 'type' => 'object', 'properties' => array( 'Date' => array( 'type' => 'string', ), 'Days' => array( 'type' => 'numeric', ), ), ), 'ID' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Transition' => array( 'type' => 'object', 'properties' => array( 'Date' => array( 'type' => 'string', ), 'Days' => array( 'type' => 'numeric', ), 'StorageClass' => array( 'type' => 'string', ), ), ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketLocationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Location' => array( 'type' => 'string', 'location' => 'body', 'filters' => array( 'strval', 'strip_tags', 'trim', ), ), ), ), 'GetBucketLoggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoggingEnabled' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetBucket' => array( 'type' => 'string', ), 'TargetGrants' => array( 'type' => 'array', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'sentAs' => 'Grant', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'TargetPrefix' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketNotificationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TopicConfiguration' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Event' => array( 'type' => 'string', ), 'Topic' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketPolicyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Policy' => array( 'type' => 'string', 'instanceOf' => 'Guzzle\\Http\\EntityBody', 'location' => 'body', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketRequestPaymentOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Payer' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketTaggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TagSet' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'sentAs' => 'Tag', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketVersioningOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MFADelete' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketWebsiteOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ErrorDocument' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Key' => array( 'type' => 'string', ), ), ), 'IndexDocument' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Suffix' => array( 'type' => 'string', ), ), ), 'RedirectAllRequestsTo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'HostName' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), ), ), 'RoutingRules' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'RoutingRule', 'type' => 'object', 'sentAs' => 'RoutingRule', 'properties' => array( 'Condition' => array( 'type' => 'object', 'properties' => array( 'HttpErrorCodeReturnedEquals' => array( 'type' => 'string', ), 'KeyPrefixEquals' => array( 'type' => 'string', ), ), ), 'Redirect' => array( 'type' => 'object', 'properties' => array( 'HostName' => array( 'type' => 'string', ), 'HttpRedirectCode' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), 'ReplaceKeyPrefixWith' => array( 'type' => 'string', ), 'ReplaceKeyWith' => array( 'type' => 'string', ), ), ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AcceptRanges' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'accept-ranges', ), 'Body' => array( 'type' => 'string', 'instanceOf' => 'Guzzle\\Http\\EntityBody', 'location' => 'body', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentLength' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'Content-Length', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'DeleteMarker' => array( 'type' => 'boolean', 'location' => 'header', 'sentAs' => 'x-amz-delete-marker', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'Expires' => array( 'type' => 'string', 'location' => 'header', ), 'LastModified' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Last-Modified', ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'MissingMeta' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'x-amz-missing-meta', ), 'Restore' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-restore', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetObjectAclOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Grants' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'AccessControlList', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'sentAs' => 'Grant', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetObjectTorrentOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Body' => array( 'type' => 'string', 'instanceOf' => 'Guzzle\\Http\\EntityBody', 'location' => 'body', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'HeadBucketOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'HeadObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AcceptRanges' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'accept-ranges', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentLength' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'Content-Length', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'DeleteMarker' => array( 'type' => 'boolean', 'location' => 'header', 'sentAs' => 'x-amz-delete-marker', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'Expires' => array( 'type' => 'string', 'location' => 'header', ), 'LastModified' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Last-Modified', ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'MissingMeta' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'x-amz-missing-meta', ), 'Restore' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-restore', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListBucketsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Buckets' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Bucket', 'type' => 'object', 'sentAs' => 'Bucket', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListMultipartUploadsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Bucket' => array( 'type' => 'string', 'location' => 'xml', ), 'CommonPrefixes' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'Prefix' => array( 'type' => 'string', ), ), ), ), 'EncodingType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Encoding-Type', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'KeyMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxUploads' => array( 'type' => 'numeric', 'location' => 'xml', ), 'NextKeyMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextUploadIdMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Prefix' => array( 'type' => 'string', 'location' => 'xml', ), 'UploadIdMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Uploads' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Upload', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Upload', 'properties' => array( 'Initiated' => array( 'type' => 'string', ), 'Initiator' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Key' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'StorageClass' => array( 'type' => 'string', ), 'UploadId' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListObjectVersionsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CommonPrefixes' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'Prefix' => array( 'type' => 'string', ), ), ), ), 'DeleteMarkers' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'DeleteMarker', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'DeleteMarker', 'properties' => array( 'IsLatest' => array( 'type' => 'boolean', ), 'Key' => array( 'type' => 'string', ), 'LastModified' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'EncodingType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Encoding-Type', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'KeyMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxKeys' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Name' => array( 'type' => 'string', 'location' => 'xml', ), 'NextKeyMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextVersionIdMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Prefix' => array( 'type' => 'string', 'location' => 'xml', ), 'VersionIdMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Versions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Version', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Version', 'properties' => array( 'ETag' => array( 'type' => 'string', ), 'IsLatest' => array( 'type' => 'boolean', ), 'Key' => array( 'type' => 'string', ), 'LastModified' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Size' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListObjectsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CommonPrefixes' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'Prefix' => array( 'type' => 'string', ), ), ), ), 'Contents' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'ETag' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'LastModified' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Size' => array( 'type' => 'numeric', ), 'StorageClass' => array( 'type' => 'string', ), ), ), ), 'EncodingType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Encoding-Type', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxKeys' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Name' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Prefix' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListPartsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Bucket' => array( 'type' => 'string', 'location' => 'xml', ), 'Initiator' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Key' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxParts' => array( 'type' => 'numeric', 'location' => 'xml', ), 'NextPartNumberMarker' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'PartNumberMarker' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Parts' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Part', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Part', 'properties' => array( 'ETag' => array( 'type' => 'string', ), 'LastModified' => array( 'type' => 'string', ), 'PartNumber' => array( 'type' => 'numeric', ), 'Size' => array( 'type' => 'numeric', ), ), ), ), 'StorageClass' => array( 'type' => 'string', 'location' => 'xml', ), 'UploadId' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketAclOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketCorsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketLifecycleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketLoggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketNotificationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketPolicyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketRequestPaymentOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketTaggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketVersioningOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketWebsiteOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), 'ObjectURL' => array( ), ), ), 'PutObjectAclOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'RestoreObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UploadPartOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UploadPartCopyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ETag' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModified' => array( 'type' => 'string', 'location' => 'xml', ), 'CopySourceVersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-version-id', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 5, 'max_attempts' => 20, ), 'BucketExists' => array( 'operation' => 'HeadBucket', 'success.type' => 'output', 'ignore_errors' => array( 'NoSuchBucket', ), ), 'BucketNotExists' => array( 'operation' => 'HeadBucket', 'success.type' => 'error', 'success.value' => 'NoSuchBucket', ), 'ObjectExists' => array( 'operation' => 'HeadObject', 'success.type' => 'output', 'ignore_errors' => array( 'NoSuchKey', ), ), ), ); sdk-2.5.2/Aws/S3/Sync/AbstractSync.php000064411532700161006750000000774512272324173014470 0ustar options = Collection::fromConfig( $options, array('concurrency' => 10), array('client', 'bucket', 'iterator', 'source_converter') ); $this->init(); } public static function getAllEvents() { return array(self::BEFORE_TRANSFER, self::AFTER_TRANSFER); } /** * Begin transferring files */ public function transfer() { // Pull out chunks of uploads to upload in parallel $iterator = new ChunkedIterator($this->options['iterator'], $this->options['concurrency']); foreach ($iterator as $files) { $this->transferFiles($files); } } /** * Create a command or special transfer action for the * * @param \SplFileInfo $file File used to build the transfer * * @return CommandInterface|callable */ abstract protected function createTransferAction(\SplFileInfo $file); /** * Hook to initialize subclasses * @codeCoverageIgnore */ protected function init() {} /** * Process and transfer a group of files * * @param array $files Files to transfer */ protected function transferFiles(array $files) { // Create the base event data object $event = array('sync' => $this, 'client' => $this->options['client']); $commands = array(); foreach ($files as $file) { if ($action = $this->createTransferAction($file)) { $event = array('command' => $action, 'file' => $file) + $event; $this->dispatch(self::BEFORE_TRANSFER, $event); if ($action instanceof CommandInterface) { $commands[] = $action; } elseif (is_callable($action)) { $action(); $this->dispatch(self::AFTER_TRANSFER, $event); } } } $this->transferCommands($commands); } /** * Transfer an array of commands in parallel * * @param array $commands Commands to transfer */ protected function transferCommands(array $commands) { if ($commands) { $this->options['client']->execute($commands); // Notify listeners that each command finished $event = array('sync' => $this, 'client' => $this->options['client']); foreach ($commands as $command) { $event['command'] = $command; $this->dispatch(self::AFTER_TRANSFER, $event); } } } } sdk-2.5.2/Aws/S3/Sync/AbstractSyncBuilder.php000064411532700161006750000002771412272324173015775 0ustar bucket = $bucket; return $this; } /** * Set the Amazon S3 client object that will send requests * * @param S3Client $client Amazon S3 client * * @return self */ public function setClient(S3Client $client) { $this->client = $client; return $this; } /** * Set a custom iterator that returns \SplFileInfo objects for the source data * * @param \Iterator $iterator * * @return self */ public function setSourceIterator(\Iterator $iterator) { $this->sourceIterator = $iterator; return $this; } /** * Set a custom object key provider instead of building one internally * * @param FileNameConverterInterface $converter Filename to object key provider * * @return self */ public function setSourceFilenameConverter(FilenameConverterInterface $converter) { $this->sourceConverter = $converter; return $this; } /** * Set a custom object key provider instead of building one internally * * @param FileNameConverterInterface $converter Filename to object key provider * * @return self */ public function setTargetFilenameConverter(FilenameConverterInterface $converter) { $this->targetConverter = $converter; return $this; } /** * Set the base directory of the files being transferred. The base directory is removed from each file path before * converting the file path to an object key or vice versa. * * @param string $baseDir Base directory, which will be deleted from each uploaded object key * * @return self */ public function setBaseDir($baseDir) { $this->baseDir = $baseDir; return $this; } /** * Specify a prefix to prepend to each Amazon S3 object key or the prefix where object are stored in a bucket * * Can be used to upload files to a pseudo sub-folder key or only download files from a pseudo sub-folder * * @param string $keyPrefix Prefix for each uploaded key * * @return self */ public function setKeyPrefix($keyPrefix) { // Removing leading slash $this->keyPrefix = ltrim($keyPrefix, '/'); return $this; } /** * Specify the delimiter used for the targeted filesystem (default delimiter is "/") * * @param string $delimiter Delimiter to use to separate paths * * @return self */ public function setDelimiter($delimiter) { $this->delimiter = $delimiter; return $this; } /** * Specify an array of operation parameters to apply to each operation executed by the sync object * * @param array $params Associative array of PutObject (upload) GetObject (download) parameters * * @return self */ public function setOperationParams(array $params) { $this->params = $params; return $this; } /** * Set the number of files that can be transferred concurrently * * @param int $concurrency Number of concurrent transfers * * @return self */ public function setConcurrency($concurrency) { $this->concurrency = $concurrency; return $this; } /** * Set to true to force transfers even if a file already exists and has not changed * * @param bool $force Set to true to force transfers without checking if it has changed * * @return self */ public function force($force = false) { $this->forcing = (bool) $force; return $this; } /** * Enable debug mode * * @param bool|resource $enabledOrResource Set to true or false to enable or disable debug output. Pass an opened * fopen resource to write to instead of writing to standard out. * @return self */ public function enableDebugOutput($enabledOrResource = true) { $this->debug = $enabledOrResource; return $this; } /** * Add a filename filter that uses a regular expression to filter out files that you do not wish to transfer. * * @param string $search Regular expression search (in preg_match format). Any filename that matches this regex * will not be transferred. * @return self */ public function addRegexFilter($search) { $this->assertFileIteratorSet(); $this->sourceIterator = new FilterIterator($this->sourceIterator, function ($i) use ($search) { return !preg_match($search, (string) $i); }); $this->sourceIterator->rewind(); return $this; } /** * Builds a UploadSync or DownloadSync object * * @return AbstractSync */ public function build() { $this->validateRequirements(); $this->sourceConverter = $this->sourceConverter ?: $this->getDefaultSourceConverter(); $this->targetConverter = $this->targetConverter ?: $this->getDefaultTargetConverter(); // Only wrap the source iterator in a changed files iterator if we are not forcing the transfers if (!$this->forcing) { $this->sourceIterator->rewind(); $this->sourceIterator = new ChangedFilesIterator( new \NoRewindIterator($this->sourceIterator), $this->getTargetIterator(), $this->sourceConverter, $this->targetConverter ); $this->sourceIterator->rewind(); } $sync = $this->specificBuild(); if ($this->params) { $this->addCustomParamListener($sync); } if ($this->debug) { $this->addDebugListener($sync, is_bool($this->debug) ? STDOUT : $this->debug); } return $sync; } /** * Hook to implement in subclasses * * @return self */ abstract protected function specificBuild(); /** * @return \Iterator */ abstract protected function getTargetIterator(); /** * @return FilenameConverterInterface */ abstract protected function getDefaultSourceConverter(); /** * @return FilenameConverterInterface */ abstract protected function getDefaultTargetConverter(); /** * Add a listener to the sync object to output debug information while transferring * * @param AbstractSync $sync Sync object to listen to * @param resource $resource Where to write debug messages */ abstract protected function addDebugListener(AbstractSync $sync, $resource); /** * Validate that the builder has the minimal requirements * * @throws RuntimeException if the builder is not configured completely */ protected function validateRequirements() { if (!$this->client) { throw new RuntimeException('No client was provided'); } if (!$this->bucket) { throw new RuntimeException('No bucket was provided'); } $this->assertFileIteratorSet(); } /** * Ensure that the base file iterator has been provided * * @throws RuntimeException */ protected function assertFileIteratorSet() { // Interesting... Need to use isset because: Object of class GlobIterator could not be converted to boolean if (!isset($this->sourceIterator)) { throw new RuntimeException('A source file iterator must be specified'); } } /** * Wraps a generated iterator in a filter iterator that removes directories * * @param \Iterator $iterator Iterator to wrap * * @return \Iterator * @throws UnexpectedValueException */ protected function filterIterator(\Iterator $iterator) { $f = new FilterIterator($iterator, function ($i) { if (!$i instanceof \SplFileInfo) { throw new UnexpectedValueException('All iterators for UploadSync must return SplFileInfo objects'); } return $i->isFile(); }); $f->rewind(); return $f; } /** * Add the custom param listener to a transfer object * * @param HasDispatcherInterface $sync */ protected function addCustomParamListener(HasDispatcherInterface $sync) { $params = $this->params; $sync->getEventDispatcher()->addListener( UploadSync::BEFORE_TRANSFER, function (Event $e) use ($params) { if ($e['command'] instanceof CommandInterface) { $e['command']->overwriteWith($params); } } ); } /** * Create an Amazon S3 file iterator based on the given builder settings * * @return OpendirIterator */ protected function createS3Iterator() { // Ensure that the stream wrapper is registered $this->client->registerStreamWrapper(); // Calculate the opendir() bucket and optional key prefix location $dir = "s3://{$this->bucket}"; if ($this->keyPrefix) { $dir .= '/' . ltrim($this->keyPrefix, '/ '); } // Use opendir so that we can pass stream context to the iterator $dh = opendir($dir, stream_context_create(array('s3' => array('delimiter' => '')))); // Add the trailing slash for the OpendirIterator concatenation if (!$this->keyPrefix) { $dir .= '/'; } return $this->filterIterator(new \NoRewindIterator(new OpendirIterator($dh, $dir))); } } sdk-2.5.2/Aws/S3/Sync/ChangedFilesIterator.php000064411532700161006750000000674012272324173016110 0ustar targetIterator = $targetIterator; $this->sourceConverter = $sourceConverter; $this->targetConverter = $targetConverter; parent::__construct($sourceIterator); } public function accept() { $current = $this->current(); $key = $this->sourceConverter->convert((string) $current); if (!($data = $this->getTargetData($key))) { return true; } // Ensure the Content-Length matches and it hasn't been modified since the mtime return $current->getSize() != $data[0] || $current->getMTime() > $data[1]; } /** * Returns an array of the files from the target iterator that were not found in the source iterator * * @return array */ public function getUnmatched() { return array_keys($this->cache); } /** * Get key information from the target iterator for a particular filename * * @param string $key Target iterator filename * * @return array|bool Returns an array of data, or false if the key is not in the iterator */ protected function getTargetData($key) { if (isset($this->cache[$key])) { $result = $this->cache[$key]; unset($this->cache[$key]); return $result; } $it = $this->targetIterator; while ($it->valid()) { $value = $it->current(); $data = array($value->getSize(), $value->getMTime()); $filename = $this->targetConverter->convert((string) $value); if ($filename == $key) { return $data; } $this->cache[$filename] = $data; $it->next(); } return false; } } sdk-2.5.2/Aws/S3/Sync/DownloadSync.php000064411532700161006750000000647212272324173014470 0ustar getPathname(); list($bucket, $key) = explode('/', substr($sourceFilename, 5), 2); $filename = $this->options['source_converter']->convert($sourceFilename); $this->createDirectory($filename); // Some S3 buckets contains nested files under the same name as a directory if (is_dir($filename)) { return false; } // Allow a previously interrupted download to resume if (file_exists($filename) && $this->options['resumable']) { return new ResumableDownload($this->options['client'], $bucket, $key, $filename); } return $this->options['client']->getCommand('GetObject', array( 'Bucket' => $bucket, 'Key' => $key, 'SaveAs' => $filename )); } /** * @codeCoverageIgnore */ protected function createDirectory($filename) { $directory = dirname($filename); // Some S3 clients create empty files to denote directories. Remove these so that we can create the directory. if (is_file($directory) && filesize($directory) == 0) { unlink($directory); } // Create the directory if it does not exist if (!is_dir($directory) && !mkdir($directory, 0777, true)) { $errors = error_get_last(); throw new RuntimeException('Could not create directory: ' . $directory . ' - ' . $errors['message']); } } protected function filterCommands(array $commands) { // Build a list of all of the directories in each command so that we don't attempt to create an empty dir in // the same parallel transfer as attempting to create a file in that dir $dirs = array(); foreach ($commands as $command) { $parts = array_values(array_filter(explode('/', $command['SaveAs']))); for ($i = 0, $total = count($parts); $i < $total; $i++) { $dir = ''; for ($j = 0; $j < $i; $j++) { $dir .= '/' . $parts[$j]; } if ($dir && !in_array($dir, $dirs)) { $dirs[] = $dir; } } } return array_filter($commands, function ($command) use ($dirs) { return !in_array($command['SaveAs'], $dirs); }); } protected function transferCommands(array $commands) { parent::transferCommands($this->filterCommands($commands)); } } sdk-2.5.2/Aws/S3/Sync/DownloadSyncBuilder.php000064411532700161006750000001011112272324173015760 0ustar directory = $directory; return $this; } /** * Call this function to allow partial downloads to be resumed if the download was previously interrupted * * @return self */ public function allowResumableDownloads() { $this->resumable = true; return $this; } protected function specificBuild() { $sync = new DownloadSync(array( 'client' => $this->client, 'bucket' => $this->bucket, 'iterator' => $this->sourceIterator, 'source_converter' => $this->sourceConverter, 'target_converter' => $this->targetConverter, 'concurrency' => $this->concurrency, 'resumable' => $this->resumable, 'directory' => $this->directory )); return $sync; } protected function getTargetIterator() { if (!$this->directory) { throw new RuntimeException('A directory is required'); } if (!is_dir($this->directory) && !mkdir($this->directory, 0777, true)) { // @codeCoverageIgnoreStart throw new RuntimeException('Unable to create root download directory: ' . $this->directory); // @codeCoverageIgnoreEnd } return $this->filterIterator( new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($this->directory)) ); } protected function getDefaultSourceConverter() { return new KeyConverter( "s3://{$this->bucket}/{$this->baseDir}", $this->directory . DIRECTORY_SEPARATOR, $this->delimiter ); } protected function getDefaultTargetConverter() { return new KeyConverter("s3://{$this->bucket}/{$this->baseDir}", '', $this->delimiter); } protected function assertFileIteratorSet() { $this->sourceIterator = $this->sourceIterator ?: $this->createS3Iterator(); } protected function addDebugListener(AbstractSync $sync, $resource) { $sync->getEventDispatcher()->addListener(UploadSync::BEFORE_TRANSFER, function (Event $e) use ($resource) { if ($e['command'] instanceof CommandInterface) { $from = $e['command']['Bucket'] . '/' . $e['command']['Key']; $to = $e['command']['SaveAs'] instanceof EntityBodyInterface ? $e['command']['SaveAs']->getUri() : $e['command']['SaveAs']; fwrite($resource, "Downloading {$from} -> {$to}\n"); } elseif ($e['command'] instanceof ResumableDownload) { $from = $e['command']->getBucket() . '/' . $e['command']->getKey(); $to = $e['command']->getFilename(); fwrite($resource, "Resuming {$from} -> {$to}\n"); } }); } } sdk-2.5.2/Aws/S3/Sync/FilenameConverterInterface.php000064411532700161006750000000162512272324173017310 0ustar baseDir = (string) $baseDir; $this->prefix = $prefix; $this->delimiter = $delimiter; } public function convert($filename) { $key = $filename; // Remove base directory from the key (only the first occurrence) if ($this->baseDir && (false !== $pos = strpos($filename, $this->baseDir))) { $key = substr_replace($key, '', $pos, strlen($this->baseDir)); } // Replace Windows directory separators to become Unix style, and convert that to the custom dir separator $key = str_replace('/', $this->delimiter, str_replace('\\', '/', $key)); // Add the key prefix and remove double slashes that are not in the protocol (e.g. prefixed with ":") $delim = preg_quote($this->delimiter); $key = preg_replace( "#(?delimiter, $this->prefix . $key ); return $key; } } sdk-2.5.2/Aws/S3/Sync/UploadSync.php000064411532700161006750000000562012272324173014137 0ustar options['multipart_upload_size']) { $this->options['multipart_upload_size'] = AbstractTransfer::MIN_PART_SIZE; } } protected function createTransferAction(\SplFileInfo $file) { // Open the file for reading $filename = $file->getPathName(); if (!($resource = fopen($filename, 'r'))) { // @codeCoverageIgnoreStart throw new RuntimeException("Could not open {$filename} for reading"); // @codeCoverageIgnoreEnd } $key = $this->options['source_converter']->convert($filename); $body = EntityBody::factory($resource); // Determine how the ACL should be applied if ($acl = $this->options['acl']) { $aclType = is_string($this->options['acl']) ? 'ACL' : 'ACP'; } else { $acl = 'private'; $aclType = 'ACL'; } // Use a multi-part upload if the file is larger than the cutoff size and is a regular file if ($body->getWrapper() == 'plainfile' && $file->getSize() >= $this->options['multipart_upload_size']) { $builder = UploadBuilder::newInstance() ->setBucket($this->options['bucket']) ->setKey($key) ->setMinPartSize($this->options['multipart_upload_size']) ->setOption($aclType, $acl) ->setClient($this->options['client']) ->setSource($body) ->setConcurrency($this->options['concurrency']); $this->dispatch( self::BEFORE_MULTIPART_BUILD, array('builder' => $builder, 'file' => $file) ); return $builder->build(); } return $this->options['client']->getCommand('PutObject', array( 'Bucket' => $this->options['bucket'], 'Key' => $key, 'Body' => $body, $aclType => $acl )); } } sdk-2.5.2/Aws/S3/Sync/UploadSyncBuilder.php000064411532700161006750000001320312272324173015442 0ustar baseDir = $path; $this->sourceIterator = $this->filterIterator(new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator( $path, FI::SKIP_DOTS | FI::UNIX_PATHS | FI::FOLLOW_SYMLINKS ))); return $this; } /** * Set a glob expression that will match files to upload to Amazon S3 * * @param string $glob Glob expression * * @return self * @link http://www.php.net/manual/en/function.glob.php */ public function uploadFromGlob($glob) { $this->sourceIterator = $this->filterIterator( new \GlobIterator($glob, FI::SKIP_DOTS | FI::UNIX_PATHS | FI::FOLLOW_SYMLINKS) ); return $this; } /** * Set a canned ACL to apply to each uploaded object * * @param string $acl Canned ACL for each upload * * @return self */ public function setAcl($acl) { $this->acp = $acl; return $this; } /** * Set an Access Control Policy to apply to each uploaded object * * @param Acp $acp Access control policy * * @return self */ public function setAcp(Acp $acp) { $this->acp = $acp; return $this; } /** * Set the multipart upload size threshold. When the size of a file exceeds this value, the file will be uploaded * using a multipart upload. * * @param int $size Size threshold * * @return self */ public function setMultipartUploadSize($size) { $this->multipartUploadSize = $size; return $this; } protected function specificBuild() { $sync = new UploadSync(array( 'client' => $this->client, 'bucket' => $this->bucket, 'iterator' => $this->sourceIterator, 'source_converter' => $this->sourceConverter, 'target_converter' => $this->targetConverter, 'concurrency' => $this->concurrency, 'multipart_upload_size' => $this->multipartUploadSize, 'acl' => $this->acp )); return $sync; } protected function addCustomParamListener(HasDispatcherInterface $sync) { // Handle the special multi-part upload event parent::addCustomParamListener($sync); $params = $this->params; $sync->getEventDispatcher()->addListener( UploadSync::BEFORE_MULTIPART_BUILD, function (Event $e) use ($params) { foreach ($params as $k => $v) { $e['builder']->setOption($k, $v); } } ); } protected function getTargetIterator() { return $this->createS3Iterator(); } protected function getDefaultSourceConverter() { return new KeyConverter($this->baseDir, $this->keyPrefix . $this->delimiter, $this->delimiter); } protected function getDefaultTargetConverter() { return new KeyConverter('s3://' . $this->bucket . '/', '', DIRECTORY_SEPARATOR); } protected function addDebugListener(AbstractSync $sync, $resource) { $sync->getEventDispatcher()->addListener(UploadSync::BEFORE_TRANSFER, function (Event $e) use ($resource) { $c = $e['command']; if ($c instanceof CommandInterface) { $uri = $c['Body']->getUri(); $size = $c['Body']->getSize(); fwrite($resource, "Uploading {$uri} -> {$c['Key']} ({$size} bytes)\n"); return; } // Multipart upload $body = $c->getSource(); $totalSize = $body->getSize(); $progress = 0; fwrite($resource, "Beginning multipart upload: " . $body->getUri() . ' -> '); fwrite($resource, $c->getState()->getFromId('Key') . " ({$totalSize} bytes)\n"); $c->getEventDispatcher()->addListener( AbstractTransfer::BEFORE_PART_UPLOAD, function ($e) use (&$progress, $totalSize, $resource) { $command = $e['command']; $size = $command['Body']->getContentLength(); $percentage = number_format(($progress / $totalSize) * 100, 2); fwrite($resource, "- Part {$command['PartNumber']} ({$size} bytes, {$percentage}%)\n"); $progress += $size; } ); }); } } sdk-2.5.2/Aws/Ses/SesClient.php000064411532700161006750000001026412272324173013300 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/ses-%s.php', Options::SIGNATURE_SERVICE => 'ses', )) ->build(); } } sdk-2.5.2/Aws/Ses/Enum/IdentityType.php000064411532700161006750000000143512272324173014746 0ustar '2010-12-01', 'endpointPrefix' => 'email', 'serviceFullName' => 'Amazon Simple Email Service', 'serviceAbbreviation' => 'Amazon SES', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Ses', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'email.us-east-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'email.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'email.eu-west-1.amazonaws.com', ), ), 'operations' => array( 'DeleteIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteIdentity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVerifiedEmailAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'deprecated' => true, 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVerifiedEmailAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EmailAddress' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetIdentityDkimAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetIdentityDkimAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetIdentityDkimAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identities' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Identities.member', 'items' => array( 'name' => 'Identity', 'type' => 'string', ), ), ), ), 'GetIdentityNotificationAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetIdentityNotificationAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetIdentityNotificationAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identities' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Identities.member', 'items' => array( 'name' => 'Identity', 'type' => 'string', ), ), ), ), 'GetIdentityVerificationAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetIdentityVerificationAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetIdentityVerificationAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identities' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Identities.member', 'items' => array( 'name' => 'Identity', 'type' => 'string', ), ), ), ), 'GetSendQuota' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSendQuotaResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSendQuota', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), ), 'GetSendStatistics' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSendStatisticsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSendStatistics', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), ), 'ListIdentities' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListIdentitiesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListIdentities', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'IdentityType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'ListVerifiedEmailAddresses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListVerifiedEmailAddressesResponse', 'responseType' => 'model', 'deprecated' => true, 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListVerifiedEmailAddresses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), ), 'SendEmail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SendEmailResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SendEmail', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Source' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Destination' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'ToAddresses' => array( 'type' => 'array', 'sentAs' => 'ToAddresses.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), 'CcAddresses' => array( 'type' => 'array', 'sentAs' => 'CcAddresses.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), 'BccAddresses' => array( 'type' => 'array', 'sentAs' => 'BccAddresses.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), ), ), 'Message' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Subject' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Data' => array( 'required' => true, 'type' => 'string', ), 'Charset' => array( 'type' => 'string', ), ), ), 'Body' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Text' => array( 'type' => 'object', 'properties' => array( 'Data' => array( 'required' => true, 'type' => 'string', ), 'Charset' => array( 'type' => 'string', ), ), ), 'Html' => array( 'type' => 'object', 'properties' => array( 'Data' => array( 'required' => true, 'type' => 'string', ), 'Charset' => array( 'type' => 'string', ), ), ), ), ), ), ), 'ReplyToAddresses' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReplyToAddresses.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), 'ReturnPath' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the action failed, and the message could not be sent. Check the error stack for more information about what caused the error.', 'class' => 'MessageRejectedException', ), ), ), 'SendRawEmail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SendRawEmailResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SendRawEmail', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Source' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Destinations' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Destinations.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), 'RawMessage' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Data' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the action failed, and the message could not be sent. Check the error stack for more information about what caused the error.', 'class' => 'MessageRejectedException', ), ), ), 'SetIdentityDkimEnabled' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetIdentityDkimEnabled', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DkimEnabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'SetIdentityFeedbackForwardingEnabled' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetIdentityFeedbackForwardingEnabled', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ForwardingEnabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'SetIdentityNotificationTopic' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetIdentityNotificationTopic', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NotificationType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopic' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'VerifyDomainDkim' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'VerifyDomainDkimResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'VerifyDomainDkim', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Domain' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'VerifyDomainIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'VerifyDomainIdentityResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'VerifyDomainIdentity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Domain' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'VerifyEmailAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'deprecated' => true, 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'VerifyEmailAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EmailAddress' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'VerifyEmailIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'VerifyEmailIdentity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EmailAddress' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'GetIdentityDkimAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DkimAttributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'object', 'properties' => array( 'DkimEnabled' => array( 'type' => 'boolean', ), 'DkimVerificationStatus' => array( 'type' => 'string', ), 'DkimTokens' => array( 'type' => 'array', 'items' => array( 'name' => 'VerificationToken', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), ), 'additionalProperties' => false, ), ), ), 'GetIdentityNotificationAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NotificationAttributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'object', 'properties' => array( 'BounceTopic' => array( 'type' => 'string', ), 'ComplaintTopic' => array( 'type' => 'string', ), 'ForwardingEnabled' => array( 'type' => 'boolean', ), ), ), ), ), 'additionalProperties' => false, ), ), ), 'GetIdentityVerificationAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VerificationAttributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'object', 'properties' => array( 'VerificationStatus' => array( 'type' => 'string', ), 'VerificationToken' => array( 'type' => 'string', ), ), ), ), ), 'additionalProperties' => false, ), ), ), 'GetSendQuotaResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Max24HourSend' => array( 'type' => 'numeric', 'location' => 'xml', ), 'MaxSendRate' => array( 'type' => 'numeric', 'location' => 'xml', ), 'SentLast24Hours' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'GetSendStatisticsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SendDataPoints' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SendDataPoint', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Timestamp' => array( 'type' => 'string', ), 'DeliveryAttempts' => array( 'type' => 'numeric', ), 'Bounces' => array( 'type' => 'numeric', ), 'Complaints' => array( 'type' => 'numeric', ), 'Rejects' => array( 'type' => 'numeric', ), ), ), ), ), ), 'ListIdentitiesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Identities' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Identity', 'type' => 'string', 'sentAs' => 'member', ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListVerifiedEmailAddressesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VerifiedEmailAddresses' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Address', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'SendEmailResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MessageId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'SendRawEmailResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MessageId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'VerifyDomainDkimResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DkimTokens' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'VerificationToken', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'VerifyDomainIdentityResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VerificationToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'ListIdentities' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxItems', 'result_key' => 'Identities', ), 'ListVerifiedEmailAddresses' => array( 'result_key' => 'VerifiedEmailAddresses', ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 3, 'max_attempts' => 20, ), 'IdentityExists' => array( 'operation' => 'GetIdentityVerificationAttributes', 'success.type' => 'output', 'success.path' => 'VerificationAttributes/*/VerificationStatus', 'success.value' => true, ), ), ); sdk-2.5.2/Aws/SimpleDb/SimpleDbClient.php000064411532700161006750000000677012272324173015221 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/simpledb-%s.php' )) ->setIteratorsConfig(array( 'token_key' => 'NextToken', 'token_param' => 'NextToken', 'operations' => array( 'ListDomains' => array( 'result_key' => 'DomainNames', 'limit_key' => 'MaxNumberOfDomains' ), 'Select' => array( 'result_key' => 'Items' ) ) )) ->build(); } } sdk-2.5.2/Aws/SimpleDb/Exception/AttributeDoesNotExistException.php000064411532700161006750000000135012272324173022441 0ustar '2009-04-15', 'endpointPrefix' => 'sdb', 'serviceFullName' => 'Amazon SimpleDB', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v2', 'namespace' => 'SimpleDb', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'BatchDeleteAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'BatchDeleteAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Items' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Item', 'items' => array( 'name' => 'Item', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'ItemName', ), 'Attributes' => array( 'type' => 'array', 'sentAs' => 'Attribute', 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'AlternateValueEncoding' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'BatchPutAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'BatchPutAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Items' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Item', 'items' => array( 'name' => 'Item', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'ItemName', ), 'Attributes' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'Attribute', 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'Value' => array( 'required' => true, 'type' => 'string', ), 'Replace' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The item name was specified more than once.', 'class' => 'DuplicateItemNameException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), array( 'reason' => 'Too many attributes in this item.', 'class' => 'NumberItemAttributesExceededException', ), array( 'reason' => 'Too many attributes in this domain.', 'class' => 'NumberDomainAttributesExceededException', ), array( 'reason' => 'Too many bytes in this domain.', 'class' => 'NumberDomainBytesExceededException', ), array( 'reason' => 'Too many items exist in a single call.', 'class' => 'NumberSubmittedItemsExceededException', ), array( 'reason' => 'Too many attributes exist in a single call.', 'class' => 'NumberSubmittedAttributesExceededException', ), ), ), 'CreateDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDomain', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'Too many domains exist per this account.', 'class' => 'NumberDomainsExceededException', ), ), ), 'DeleteAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ItemName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Attribute', 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'AlternateValueEncoding' => array( 'type' => 'string', ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), array( 'reason' => 'The specified attribute does not exist.', 'class' => 'AttributeDoesNotExistException', ), ), ), 'DeleteDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDomain', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), ), ), 'DomainMetadata' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DomainMetadataResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DomainMetadata', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), ), ), 'GetAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetAttributesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ItemName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AttributeName', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), ), ), 'ListDomains' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListDomainsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListDomains', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'MaxNumberOfDomains' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The specified NextToken is not valid.', 'class' => 'InvalidNextTokenException', ), ), ), 'PutAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ItemName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Attribute', 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'Value' => array( 'required' => true, 'type' => 'string', ), 'Replace' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), array( 'reason' => 'Too many attributes in this domain.', 'class' => 'NumberDomainAttributesExceededException', ), array( 'reason' => 'Too many bytes in this domain.', 'class' => 'NumberDomainBytesExceededException', ), array( 'reason' => 'Too many attributes in this item.', 'class' => 'NumberItemAttributesExceededException', ), array( 'reason' => 'The specified attribute does not exist.', 'class' => 'AttributeDoesNotExistException', ), ), ), 'Select' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SelectResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'Select', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'SelectExpression' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The specified NextToken is not valid.', 'class' => 'InvalidNextTokenException', ), array( 'reason' => 'Too many predicates exist in the query expression.', 'class' => 'InvalidNumberPredicatesException', ), array( 'reason' => 'Too many predicates exist in the query expression.', 'class' => 'InvalidNumberValueTestsException', ), array( 'reason' => 'The specified query expression syntax is not valid.', 'class' => 'InvalidQueryExpressionException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), array( 'reason' => 'A timeout occurred when attempting to query the specified domain with specified query expression.', 'class' => 'RequestTimeoutException', ), array( 'reason' => 'Too many attributes requested.', 'class' => 'TooManyRequestedAttributesException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DomainMetadataResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ItemCount' => array( 'type' => 'numeric', 'location' => 'xml', ), 'ItemNamesSizeBytes' => array( 'type' => 'numeric', 'location' => 'xml', ), 'AttributeNameCount' => array( 'type' => 'numeric', 'location' => 'xml', ), 'AttributeNamesSizeBytes' => array( 'type' => 'numeric', 'location' => 'xml', ), 'AttributeValueCount' => array( 'type' => 'numeric', 'location' => 'xml', ), 'AttributeValuesSizeBytes' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Timestamp' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'GetAttributesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Attribute', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'sentAs' => 'Attribute', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'AlternateValueEncoding' => array( 'type' => 'string', ), ), ), ), ), ), 'ListDomainsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DomainNames' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'DomainName', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'DomainName', 'type' => 'string', 'sentAs' => 'DomainName', ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'SelectResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Item', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'Item', 'type' => 'object', 'sentAs' => 'Item', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'array', 'sentAs' => 'Attribute', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'sentAs' => 'Attribute', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'AlternateValueEncoding' => array( 'type' => 'string', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), ); sdk-2.5.2/Aws/Sns/SnsClient.php000064411532700161006750000001204212272324173013316 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/sns-%s.php' )) ->build(); } } sdk-2.5.2/Aws/Sns/Exception/AuthorizationErrorException.php000064411532700161006750000000137512272324173021112 0ustar array( 'Message', 'MessageId', 'Timestamp', 'TopicArn', 'Type', 'Signature', 'SigningCertURL', ), 'SubscriptionConfirmation' => array( 'SubscribeURL', 'Token' ), 'UnsubscribeConfirmation' => array( 'SubscribeURL', 'Token' ), ); protected static $signableKeys = array( 'Message', 'MessageId', 'Subject', 'SubscribeURL', 'Timestamp', 'Token', 'TopicArn', 'Type', ); /** * @var Collection The message data */ protected $data; /** * Creates a Message object from an array of raw message data * * @param array $data The message data * * @return Message * @throws InvalidArgumentException If a valid type is not provided or there are other required keys missing */ public static function fromArray(array $data) { // Make sure the type key is set if (!isset($data['Type'])) { throw new InvalidArgumentException('The "Type" key must be provided to instantiate a Message object.'); } // Determine required keys and create a collection from the message data $requiredKeys = array_merge( self::$requiredKeys['__default'], isset(self::$requiredKeys[$data['Type']]) ? self::$requiredKeys[$data['Type']] : array() ); $data = Collection::fromConfig($data, array(), $requiredKeys); return new self($data); } /** * Creates a message object from the raw POST data * * @return Message * @throws UnexpectedValueException If the POST data is absent, or not a valid JSON document */ public static function fromRawPostData() { $data = json_decode(file_get_contents('php://input'), true); if (!is_array($data)) { throw new UnexpectedValueException('POST data absent, or not a valid JSON document', json_last_error()); } return self::fromArray($data); } /** * @param Collection $data A Collection of message data with all required keys */ public function __construct(Collection $data) { $this->data = $data; } /** * Get the entire message data as a Collection * * @return Collection */ public function getData() { return $this->data; } /** * Gets a single key from the message data * * @return string */ public function get($key) { return $this->data->get($key); } /** * Builds a newline delimited string to sign according to the specs * * @return string * @link http://docs.aws.amazon.com/sns/latest/gsg/SendMessageToHttp.verify.signature.html */ public function getStringToSign() { $stringToSign = ''; $data = $this->data->toArray(); ksort($data); foreach ($data as $key => $value) { if (in_array($key, self::$signableKeys)) { $stringToSign .= "{$key}\n{$value}\n"; } } return $stringToSign; } } sdk-2.5.2/Aws/Sns/MessageValidator/MessageValidator.php000064411532700161006750000000736612272324173020115 0ustar client = $client ?: new Client(); } /** * Validates a message from SNS to ensure that it was delivered by AWS * * @param Message $message The message to validate * * @throws CannotGetPublicKeyFromCertificateException If the certificate cannot be retrieved * @throws CertificateFromUnrecognizedSourceException If the certificate's source cannot be verified * @throws InvalidMessageSignatureException If the message's signature is invalid */ public function validate(Message $message) { // Get the cert's URL and ensure it is from AWS $certUrl = Url::factory($message->get('SigningCertURL')); if ('.amazonaws.com' != substr($certUrl->getHost(), -14)) { throw new CertificateFromUnrecognizedSourceException(); } // Get the cert itself and extract the public key $certificate = $this->client->get((string) $certUrl)->send()->getBody(); $publicKey = openssl_get_publickey($certificate); if (!$publicKey) { throw new CannotGetPublicKeyFromCertificateException(); } // Verify the signature of the message $stringToSign = $message->getStringToSign(); $incomingSignature = base64_decode($message->get('Signature')); if (!openssl_verify($stringToSign, $incomingSignature, $publicKey, OPENSSL_ALGO_SHA1)) { throw new InvalidMessageSignatureException(); } } /** * Determines if a message is valid and that is was delivered by AWS. This method does not throw exceptions and * returns a simple boolean value. * * @param Message $message The message to validate * * @return bool */ public function isValid(Message $message) { try { $this->validate($message); return true; } catch (SnsMessageValidatorException $e) { return false; } } } sdk-2.5.2/Aws/Sns/MessageValidator/Exception/CannotGetPublicKeyFromCertificateException.php000064411532700161006750000000156412272324173027153 0ustar '2010-03-31', 'endpointPrefix' => 'sns', 'serviceFullName' => 'Amazon Simple Notification Service', 'serviceAbbreviation' => 'Amazon SNS', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Sns', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AddPermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddPermission', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Label' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AWSAccountId' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AWSAccountId.member', 'items' => array( 'name' => 'delegate', 'type' => 'string', ), ), 'ActionName' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ActionName.member', 'items' => array( 'name' => 'action', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'ConfirmSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfirmSubscriptionResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ConfirmSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Token' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AuthenticateOnUnsubscribe' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the customer already owns the maximum allowed number of subscriptions.', 'class' => 'SubscriptionLimitExceededException', ), array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'CreatePlatformApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreatePlatformApplicationResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreatePlatformApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Platform' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attributes.entry', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'String', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'CreatePlatformEndpoint' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateEndpointResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreatePlatformEndpoint', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Token' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CustomUserData' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attributes.entry', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'String', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'CreateTopic' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateTopicResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateTopic', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates that the customer already owns the maximum allowed number of topics.', 'class' => 'TopicLimitExceededException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'DeleteEndpoint' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteEndpoint', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'EndpointArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'DeletePlatformApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeletePlatformApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'DeleteTopic' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteTopic', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'GetEndpointAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetEndpointAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetEndpointAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'EndpointArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'GetPlatformApplicationAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetPlatformApplicationAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetPlatformApplicationAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'GetSubscriptionAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSubscriptionAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSubscriptionAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'SubscriptionArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'GetTopicAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetTopicAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetTopicAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'ListEndpointsByPlatformApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListEndpointsByPlatformApplicationResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListEndpointsByPlatformApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'ListPlatformApplications' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListPlatformApplicationsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListPlatformApplications', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'ListSubscriptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListSubscriptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListSubscriptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'ListSubscriptionsByTopic' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListSubscriptionsByTopicResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListSubscriptionsByTopic', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'ListTopics' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListTopicsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListTopics', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'Publish' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'PublishResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'Publish', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'TargetArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Message' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Subject' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MessageStructure' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Exception error indicating endpoint disabled.', 'class' => 'EndpointDisabledException', ), array( 'reason' => 'Exception error indicating platform application disabled.', 'class' => 'PlatformApplicationDisabledException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'RemovePermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemovePermission', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Label' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'SetEndpointAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetEndpointAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'EndpointArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attributes.entry', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'String', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'SetPlatformApplicationAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetPlatformApplicationAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attributes.entry', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'String', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'SetSubscriptionAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetSubscriptionAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'SubscriptionArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeValue' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'SetTopicAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetTopicAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeValue' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'Subscribe' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SubscribeResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'Subscribe', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Protocol' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Endpoint' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the customer already owns the maximum allowed number of subscriptions.', 'class' => 'SubscriptionLimitExceededException', ), array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'Unsubscribe' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'Unsubscribe', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'SubscriptionArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ConfirmSubscriptionResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SubscriptionArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'CreatePlatformApplicationResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PlatformApplicationArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'CreateEndpointResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EndpointArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'CreateTopicResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TopicArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetEndpointAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'GetPlatformApplicationAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'GetSubscriptionAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'GetTopicAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'ListEndpointsByPlatformApplicationResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Endpoints' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Endpoint', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'EndpointArn' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListPlatformApplicationsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PlatformApplications' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'PlatformApplication', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PlatformApplicationArn' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListSubscriptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subscriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Subscription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SubscriptionArn' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), 'TopicArn' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListSubscriptionsByTopicResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subscriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Subscription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SubscriptionArn' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), 'TopicArn' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListTopicsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Topics' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Topic', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'TopicArn' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'PublishResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MessageId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'SubscribeResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SubscriptionArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'ListEndpointsByPlatformApplication' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Endpoints', ), 'ListPlatformApplications' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'PlatformApplications', ), 'ListSubscriptions' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Subscriptions', ), 'ListSubscriptionsByTopic' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Subscriptions', ), 'ListTopics' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Topics/*/TopicArn', ), ), ), ); sdk-2.5.2/Aws/Sqs/Md5ValidatorListener.php000064411532700161006750000000326712272324173015431 0ustar array('onCommandBeforeSend', -255)); } /** * Validates the MD5OfBody attribute against the body * * @param Event $event Event emitted * @throws SqsException when an MD5 mismatch occurs */ public function onCommandBeforeSend(Event $event) { if ($event['command']->getName() != 'ReceiveMessage') { return; } $result = $event['command']->getResult(); if (isset($result['Messages'])) { foreach ($result['Messages'] as $message) { if ($message['MD5OfBody'] != md5($message['Body'])) { throw new SqsException('Body MD5 mismatch for ' . var_export($message, true)); } } } } } sdk-2.5.2/Aws/Sqs/QueueUrlListener.php000064411532700161006750000000310612272324173014675 0ustar array('onCommandBeforeSend', -255)); } /** * Updates the request URL to use the Queue URL * * @param Event $event Event emitted */ public function onCommandBeforeSend(Event $event) { /** @var $command AbstractCommand */ $command = $event['command']; if ($command->hasKey('QueueUrl')) { $request = $command->getRequest(); $requestUrl = $request->getUrl(true); $request->setUrl($requestUrl->combine($command->get('QueueUrl'))); $request->getParams()->remove('QueueUrl'); } } } sdk-2.5.2/Aws/Sqs/SqsClient.php000064411532700161006750000001037712272324173013335 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/sqs-%s.php' )) ->build(); $client->addSubscriber(new QueueUrlListener()); $client->addSubscriber(new Md5ValidatorListener()); return $client; } /** * Converts a queue URL into a queue ARN. * * @param string $queueUrl The queue URL to perform the action on. Retrieved when the queue is first created. * * @return string An ARN representation of the queue URL. */ public function getQueueArn($queueUrl) { return strtr($queueUrl, array( 'http://' => 'arn:aws:', 'https://' => 'arn:aws:', '.amazonaws.com' => '', '/' => ':', '.' => ':', )); } } sdk-2.5.2/Aws/Sqs/Enum/MessageAttribute.php000064411532700161006750000000173012272324173015575 0ustar '2012-11-05', 'endpointPrefix' => 'sqs', 'serviceFullName' => 'Amazon Simple Queue Service', 'serviceAbbreviation' => 'Amazon SQS', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Sqs', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AddPermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddPermission', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Label' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AWSAccountIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AWSAccountId', 'items' => array( 'name' => 'AWSAccountId', 'type' => 'string', ), ), 'Actions' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ActionName', 'items' => array( 'name' => 'ActionName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The action that you requested would violate a limit. For example, ReceiveMessage returns this error if the maximum number of messages inflight has already been reached. AddPermission returns this error if the maximum number of permissions for the queue has already been reached.', 'class' => 'OverLimitException', ), ), ), 'ChangeMessageVisibility' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ChangeMessageVisibility', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReceiptHandle' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VisibilityTimeout' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The message referred to is not in flight.', 'class' => 'MessageNotInflightException', ), array( 'reason' => 'The receipt handle provided is not valid.', 'class' => 'ReceiptHandleIsInvalidException', ), ), ), 'ChangeMessageVisibilityBatch' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ChangeMessageVisibilityBatchResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ChangeMessageVisibilityBatch', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Entries' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ChangeMessageVisibilityBatchRequestEntry', 'items' => array( 'name' => 'ChangeMessageVisibilityBatchRequestEntry', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'ReceiptHandle' => array( 'required' => true, 'type' => 'string', ), 'VisibilityTimeout' => array( 'type' => 'numeric', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Batch request contains more number of entries than permissible.', 'class' => 'TooManyEntriesInBatchRequestException', ), array( 'reason' => 'Batch request does not contain an entry.', 'class' => 'EmptyBatchRequestException', ), array( 'reason' => 'Two or more batch entries have the same Id in the request.', 'class' => 'BatchEntryIdsNotDistinctException', ), array( 'reason' => 'The Id of a batch entry in a batch request does not abide by the specification.', 'class' => 'InvalidBatchEntryIdException', ), ), ), 'CreateQueue' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateQueueResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateQueue', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attribute', 'data' => array( 'keyName' => 'Name', 'valueName' => 'Value', ), 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'QueueAttributeName', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'You must wait 60 seconds after deleting a queue before you can create another with the same name.', 'class' => 'QueueDeletedRecentlyException', ), array( 'reason' => 'A queue already exists with this name. Amazon SQS returns this error only if the request includes attributes whose values differ from those of the existing queue.', 'class' => 'QueueNameExistsException', ), ), ), 'DeleteMessage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteMessage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReceiptHandle' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The receipt handle is not valid for the current version.', 'class' => 'InvalidIdFormatException', ), array( 'reason' => 'The receipt handle provided is not valid.', 'class' => 'ReceiptHandleIsInvalidException', ), ), ), 'DeleteMessageBatch' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeleteMessageBatchResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteMessageBatch', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Entries' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DeleteMessageBatchRequestEntry', 'items' => array( 'name' => 'DeleteMessageBatchRequestEntry', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'ReceiptHandle' => array( 'required' => true, 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Batch request contains more number of entries than permissible.', 'class' => 'TooManyEntriesInBatchRequestException', ), array( 'reason' => 'Batch request does not contain an entry.', 'class' => 'EmptyBatchRequestException', ), array( 'reason' => 'Two or more batch entries have the same Id in the request.', 'class' => 'BatchEntryIdsNotDistinctException', ), array( 'reason' => 'The Id of a batch entry in a batch request does not abide by the specification.', 'class' => 'InvalidBatchEntryIdException', ), ), ), 'DeleteQueue' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteQueue', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetQueueAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetQueueAttributesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetQueueAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AttributeName', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The attribute referred to does not exist.', 'class' => 'InvalidAttributeNameException', ), ), ), 'GetQueueUrl' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetQueueUrlResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetQueueUrl', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'QueueOwnerAWSAccountId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The queue referred to does not exist.', 'class' => 'QueueDoesNotExistException', ), ), ), 'ListDeadLetterSourceQueues' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListDeadLetterSourceQueuesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListDeadLetterSourceQueues', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The queue referred to does not exist.', 'class' => 'QueueDoesNotExistException', ), ), ), 'ListQueues' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListQueuesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListQueues', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueNamePrefix' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReceiveMessage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReceiveMessageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReceiveMessage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AttributeName', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'MaxNumberOfMessages' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'VisibilityTimeout' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'WaitTimeSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The action that you requested would violate a limit. For example, ReceiveMessage returns this error if the maximum number of messages inflight has already been reached. AddPermission returns this error if the maximum number of permissions for the queue has already been reached.', 'class' => 'OverLimitException', ), ), ), 'RemovePermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemovePermission', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Label' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'SendMessage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SendMessageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SendMessage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MessageBody' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DelaySeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The message contains characters outside the allowed set.', 'class' => 'InvalidMessageContentsException', ), ), ), 'SendMessageBatch' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SendMessageBatchResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SendMessageBatch', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Entries' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SendMessageBatchRequestEntry', 'items' => array( 'name' => 'SendMessageBatchRequestEntry', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'MessageBody' => array( 'required' => true, 'type' => 'string', ), 'DelaySeconds' => array( 'type' => 'numeric', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Batch request contains more number of entries than permissible.', 'class' => 'TooManyEntriesInBatchRequestException', ), array( 'reason' => 'Batch request does not contain an entry.', 'class' => 'EmptyBatchRequestException', ), array( 'reason' => 'Two or more batch entries have the same Id in the request.', 'class' => 'BatchEntryIdsNotDistinctException', ), array( 'reason' => 'The length of all the messages put together is more than the limit.', 'class' => 'BatchRequestTooLongException', ), array( 'reason' => 'The Id of a batch entry in a batch request does not abide by the specification.', 'class' => 'InvalidBatchEntryIdException', ), ), ), 'SetQueueAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetQueueAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attribute', 'data' => array( 'keyName' => 'Name', 'valueName' => 'Value', ), 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'QueueAttributeName', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The attribute referred to does not exist.', 'class' => 'InvalidAttributeNameException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ChangeMessageVisibilityBatchResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Successful' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'ChangeMessageVisibilityBatchResultEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'ChangeMessageVisibilityBatchResultEntry', 'type' => 'object', 'sentAs' => 'ChangeMessageVisibilityBatchResultEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), ), ), ), 'Failed' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'BatchResultErrorEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'BatchResultErrorEntry', 'type' => 'object', 'sentAs' => 'BatchResultErrorEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'SenderFault' => array( 'type' => 'boolean', ), 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), 'CreateQueueResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'QueueUrl' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DeleteMessageBatchResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Successful' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'DeleteMessageBatchResultEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'DeleteMessageBatchResultEntry', 'type' => 'object', 'sentAs' => 'DeleteMessageBatchResultEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), ), ), ), 'Failed' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'BatchResultErrorEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'BatchResultErrorEntry', 'type' => 'object', 'sentAs' => 'BatchResultErrorEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'SenderFault' => array( 'type' => 'boolean', ), 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), 'GetQueueAttributesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Attribute', 'data' => array( 'xmlFlattened' => true, 'xmlMap' => array( 'Policy', 'VisibilityTimeout', 'MaximumMessageSize', 'MessageRetentionPeriod', 'ApproximateNumberOfMessages', 'ApproximateNumberOfMessagesNotVisible', 'CreatedTimestamp', 'LastModifiedTimestamp', 'QueueArn', 'ApproximateNumberOfMessagesDelayed', 'DelaySeconds', 'ReceiveMessageWaitTimeSeconds', 'RedrivePolicy', ), ), 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'Attribute', 'Name', 'Value', ), ), ), 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'sentAs' => 'Attribute', 'additionalProperties' => true, 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'GetQueueUrlResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'QueueUrl' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListDeadLetterSourceQueuesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'queueUrls' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'QueueUrl', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'QueueUrl', 'type' => 'string', 'sentAs' => 'QueueUrl', ), ), ), ), 'ListQueuesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'QueueUrls' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'QueueUrl', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'QueueUrl', 'type' => 'string', 'sentAs' => 'QueueUrl', ), ), ), ), 'ReceiveMessageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Messages' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Message', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'Message', 'type' => 'object', 'sentAs' => 'Message', 'properties' => array( 'MessageId' => array( 'type' => 'string', ), 'ReceiptHandle' => array( 'type' => 'string', ), 'MD5OfBody' => array( 'type' => 'string', ), 'Body' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'array', 'sentAs' => 'Attribute', 'data' => array( 'xmlFlattened' => true, 'xmlMap' => array( 'Policy', 'VisibilityTimeout', 'MaximumMessageSize', 'MessageRetentionPeriod', 'ApproximateNumberOfMessages', 'ApproximateNumberOfMessagesNotVisible', 'CreatedTimestamp', 'LastModifiedTimestamp', 'QueueArn', 'ApproximateNumberOfMessagesDelayed', 'DelaySeconds', 'ReceiveMessageWaitTimeSeconds', 'RedrivePolicy', ), ), 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'Attribute', 'Name', 'Value', ), ), ), 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'sentAs' => 'Attribute', 'additionalProperties' => true, 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), ), ), 'SendMessageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MD5OfMessageBody' => array( 'type' => 'string', 'location' => 'xml', ), 'MessageId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'SendMessageBatchResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Successful' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'SendMessageBatchResultEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'SendMessageBatchResultEntry', 'type' => 'object', 'sentAs' => 'SendMessageBatchResultEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'MessageId' => array( 'type' => 'string', ), 'MD5OfMessageBody' => array( 'type' => 'string', ), ), ), ), 'Failed' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'BatchResultErrorEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'BatchResultErrorEntry', 'type' => 'object', 'sentAs' => 'BatchResultErrorEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'SenderFault' => array( 'type' => 'boolean', ), 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'ListDeadLetterSourceQueues' => array( 'result_key' => 'queueUrls', ), 'ListQueues' => array( 'result_key' => 'QueueUrls', ), ), ), ); sdk-2.5.2/Aws/StorageGateway/StorageGatewayClient.php000064411532700161006750000002102612272324173017666 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/storagegateway-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } sdk-2.5.2/Aws/StorageGateway/Enum/BandwidthType.php000064411532700161006750000000147012272324173017254 0ustar '2013-06-30', 'endpointPrefix' => 'storagegateway', 'serviceFullName' => 'AWS Storage Gateway', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'StorageGateway_20130630.', 'signatureVersion' => 'v4', 'namespace' => 'StorageGateway', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.cn-north-1.amazonaws.com.cn', ), ), 'operations' => array( 'ActivateGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivateGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ActivateGateway', ), 'ActivationKey' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 50, ), 'GatewayName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 255, ), 'GatewayTimezone' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 10, ), 'GatewayRegion' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 25, ), 'GatewayType' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 20, ), 'TapeDriveType' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 50, ), 'MediumChangerType' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'AddCache' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddCacheOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.AddCache', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'DiskIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', 'minLength' => 1, 'maxLength' => 300, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'AddUploadBuffer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddUploadBufferOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.AddUploadBuffer', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'DiskIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', 'minLength' => 1, 'maxLength' => 300, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'AddWorkingStorage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddWorkingStorageOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.AddWorkingStorage', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'DiskIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', 'minLength' => 1, 'maxLength' => 300, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CancelArchival' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CancelArchivalOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CancelArchival', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CancelRetrieval' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CancelRetrievalOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CancelRetrieval', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateCachediSCSIVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateCachediSCSIVolumeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateCachediSCSIVolume', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'VolumeSizeInBytes' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'json', ), 'TargetName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 200, ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'ClientToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 5, 'maxLength' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateSnapshotOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateSnapshot', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'SnapshotDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateSnapshotFromVolumeRecoveryPoint' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateSnapshotFromVolumeRecoveryPointOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateSnapshotFromVolumeRecoveryPoint', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'SnapshotDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateStorediSCSIVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateStorediSCSIVolumeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateStorediSCSIVolume', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'DiskId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 300, ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'json', ), 'PreserveExistingData' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'TargetName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 200, ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateTapes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateTapesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateTapes', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeSizeInBytes' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'minimum' => 107374182400, 'maximum' => 2748779069440, ), 'ClientToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 5, 'maxLength' => 100, ), 'NumTapesToCreate' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 10, ), 'TapeBarcodePrefix' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 4, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteBandwidthRateLimit' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteBandwidthRateLimitOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteBandwidthRateLimit', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'BandwidthType' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 25, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteChapCredentials' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteChapCredentialsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteChapCredentials', ), 'TargetARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 800, ), 'InitiatorName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteGateway', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteSnapshotSchedule' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteSnapshotScheduleOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteSnapshotSchedule', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteTape' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteTapeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteTape', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteTapeArchive' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteTapeArchiveOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteTapeArchive', ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteVolumeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteVolume', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeBandwidthRateLimit' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeBandwidthRateLimitOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeBandwidthRateLimit', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeCache' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCacheOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeCache', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeCachediSCSIVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCachediSCSIVolumesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeCachediSCSIVolumes', ), 'VolumeARNs' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeChapCredentials' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeChapCredentialsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeChapCredentials', ), 'TargetARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 800, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeGatewayInformation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeGatewayInformationOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeGatewayInformation', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeMaintenanceStartTime' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeMaintenanceStartTimeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeMaintenanceStartTime', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeSnapshotSchedule' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeSnapshotScheduleOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeSnapshotSchedule', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeStorediSCSIVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStorediSCSIVolumesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeStorediSCSIVolumes', ), 'VolumeARNs' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTapeArchives' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTapeArchivesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeTapeArchives', ), 'TapeARNs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTapeRecoveryPoints' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTapeRecoveryPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeTapeRecoveryPoints', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTapes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTapesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeTapes', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeARNs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeUploadBuffer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeUploadBufferOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeUploadBuffer', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeVTLDevices' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeVTLDevicesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeVTLDevices', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'VTLDeviceARNs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VTLDeviceARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeWorkingStorage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeWorkingStorageOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeWorkingStorage', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DisableGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DisableGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DisableGateway', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ListGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListGatewaysOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ListGateways', ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ListLocalDisks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListLocalDisksOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ListLocalDisks', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ListVolumeRecoveryPoints' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListVolumeRecoveryPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ListVolumeRecoveryPoints', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ListVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListVolumesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ListVolumes', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'RetrieveTapeArchive' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RetrieveTapeArchiveOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.RetrieveTapeArchive', ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'RetrieveTapeRecoveryPoint' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RetrieveTapeRecoveryPointOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.RetrieveTapeRecoveryPoint', ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ShutdownGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ShutdownGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ShutdownGateway', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'StartGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'StartGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.StartGateway', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateBandwidthRateLimit' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateBandwidthRateLimitOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateBandwidthRateLimit', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'AverageUploadRateLimitInBitsPerSec' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 51200, ), 'AverageDownloadRateLimitInBitsPerSec' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 102400, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateChapCredentials' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateChapCredentialsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateChapCredentials', ), 'TargetARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 800, ), 'SecretToAuthenticateInitiator' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 12, 'maxLength' => 16, ), 'InitiatorName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), 'SecretToAuthenticateTarget' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 12, 'maxLength' => 16, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateGatewayInformation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateGatewayInformationOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateGatewayInformation', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'GatewayName' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 255, ), 'GatewayTimezone' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 10, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateGatewaySoftwareNow' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateGatewaySoftwareNowOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateGatewaySoftwareNow', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateMaintenanceStartTime' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateMaintenanceStartTimeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateMaintenanceStartTime', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'HourOfDay' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'maximum' => 23, ), 'MinuteOfHour' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'maximum' => 59, ), 'DayOfWeek' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'maximum' => 6, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateSnapshotSchedule' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateSnapshotScheduleOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateSnapshotSchedule', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'StartAt' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'maximum' => 23, ), 'RecurrenceInHours' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 24, ), 'Description' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), ), 'models' => array( 'ActivateGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'AddCacheOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'AddUploadBufferOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'AddWorkingStorageOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CancelArchivalOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CancelRetrievalOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateCachediSCSIVolumeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'TargetARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateSnapshotOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateSnapshotFromVolumeRecoveryPointOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeRecoveryPointTime' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateStorediSCSIVolumeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeSizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'TargetARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateTapesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARNs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeARN', 'type' => 'string', ), ), ), ), 'DeleteBandwidthRateLimitOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteChapCredentialsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TargetARN' => array( 'type' => 'string', 'location' => 'json', ), 'InitiatorName' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteSnapshotScheduleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteTapeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteTapeArchiveOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteVolumeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeBandwidthRateLimitOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'AverageUploadRateLimitInBitsPerSec' => array( 'type' => 'numeric', 'location' => 'json', ), 'AverageDownloadRateLimitInBitsPerSec' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DescribeCacheOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'DiskIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', ), ), 'CacheAllocatedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'CacheUsedPercentage' => array( 'type' => 'numeric', 'location' => 'json', ), 'CacheDirtyPercentage' => array( 'type' => 'numeric', 'location' => 'json', ), 'CacheHitPercentage' => array( 'type' => 'numeric', 'location' => 'json', ), 'CacheMissPercentage' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DescribeCachediSCSIVolumesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CachediSCSIVolumes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'CachediSCSIVolume', 'type' => 'object', 'properties' => array( 'VolumeARN' => array( 'type' => 'string', ), 'VolumeId' => array( 'type' => 'string', ), 'VolumeType' => array( 'type' => 'string', ), 'VolumeStatus' => array( 'type' => 'string', ), 'VolumeSizeInBytes' => array( 'type' => 'numeric', ), 'VolumeProgress' => array( 'type' => 'numeric', ), 'SourceSnapshotId' => array( 'type' => 'string', ), 'VolumeiSCSIAttributes' => array( 'type' => 'object', 'properties' => array( 'TargetARN' => array( 'type' => 'string', ), 'NetworkInterfaceId' => array( 'type' => 'string', ), 'NetworkInterfacePort' => array( 'type' => 'numeric', ), 'LunNumber' => array( 'type' => 'numeric', ), 'ChapEnabled' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'DescribeChapCredentialsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ChapCredentials' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ChapInfo', 'type' => 'object', 'properties' => array( 'TargetARN' => array( 'type' => 'string', ), 'SecretToAuthenticateInitiator' => array( 'type' => 'string', ), 'InitiatorName' => array( 'type' => 'string', ), 'SecretToAuthenticateTarget' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeGatewayInformationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'GatewayId' => array( 'type' => 'string', 'location' => 'json', ), 'GatewayTimezone' => array( 'type' => 'string', 'location' => 'json', ), 'GatewayState' => array( 'type' => 'string', 'location' => 'json', ), 'GatewayNetworkInterfaces' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'NetworkInterface', 'type' => 'object', 'properties' => array( 'Ipv4Address' => array( 'type' => 'string', ), 'MacAddress' => array( 'type' => 'string', ), 'Ipv6Address' => array( 'type' => 'string', ), ), ), ), 'GatewayType' => array( 'type' => 'string', 'location' => 'json', ), 'NextUpdateAvailabilityDate' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeMaintenanceStartTimeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'HourOfDay' => array( 'type' => 'numeric', 'location' => 'json', ), 'MinuteOfHour' => array( 'type' => 'numeric', 'location' => 'json', ), 'DayOfWeek' => array( 'type' => 'numeric', 'location' => 'json', ), 'Timezone' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeSnapshotScheduleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'StartAt' => array( 'type' => 'numeric', 'location' => 'json', ), 'RecurrenceInHours' => array( 'type' => 'numeric', 'location' => 'json', ), 'Description' => array( 'type' => 'string', 'location' => 'json', ), 'Timezone' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeStorediSCSIVolumesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StorediSCSIVolumes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StorediSCSIVolume', 'type' => 'object', 'properties' => array( 'VolumeARN' => array( 'type' => 'string', ), 'VolumeId' => array( 'type' => 'string', ), 'VolumeType' => array( 'type' => 'string', ), 'VolumeStatus' => array( 'type' => 'string', ), 'VolumeSizeInBytes' => array( 'type' => 'numeric', ), 'VolumeProgress' => array( 'type' => 'numeric', ), 'VolumeDiskId' => array( 'type' => 'string', ), 'SourceSnapshotId' => array( 'type' => 'string', ), 'PreservedExistingData' => array( 'type' => 'boolean', ), 'VolumeiSCSIAttributes' => array( 'type' => 'object', 'properties' => array( 'TargetARN' => array( 'type' => 'string', ), 'NetworkInterfaceId' => array( 'type' => 'string', ), 'NetworkInterfacePort' => array( 'type' => 'numeric', ), 'LunNumber' => array( 'type' => 'numeric', ), 'ChapEnabled' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'DescribeTapeArchivesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeArchives' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeArchive', 'type' => 'object', 'properties' => array( 'TapeARN' => array( 'type' => 'string', ), 'TapeBarcode' => array( 'type' => 'string', ), 'TapeSizeInBytes' => array( 'type' => 'numeric', ), 'CompletionTime' => array( 'type' => 'string', ), 'RetrievedTo' => array( 'type' => 'string', ), 'TapeStatus' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeTapeRecoveryPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'TapeRecoveryPointInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeRecoveryPointInfo', 'type' => 'object', 'properties' => array( 'TapeARN' => array( 'type' => 'string', ), 'TapeRecoveryPointTime' => array( 'type' => 'string', ), 'TapeSizeInBytes' => array( 'type' => 'numeric', ), 'TapeStatus' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeTapesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Tapes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Tape', 'type' => 'object', 'properties' => array( 'TapeARN' => array( 'type' => 'string', ), 'TapeBarcode' => array( 'type' => 'string', ), 'TapeSizeInBytes' => array( 'type' => 'numeric', ), 'TapeStatus' => array( 'type' => 'string', ), 'VTLDevice' => array( 'type' => 'string', ), 'Progress' => array( 'type' => 'numeric', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeUploadBufferOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'DiskIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', ), ), 'UploadBufferUsedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'UploadBufferAllocatedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DescribeVTLDevicesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'VTLDevices' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VTLDevice', 'type' => 'object', 'properties' => array( 'VTLDeviceARN' => array( 'type' => 'string', ), 'VTLDeviceType' => array( 'type' => 'string', ), 'VTLDeviceVendor' => array( 'type' => 'string', ), 'VTLDeviceProductIdentifier' => array( 'type' => 'string', ), 'DeviceiSCSIAttributes' => array( 'type' => 'object', 'properties' => array( 'TargetARN' => array( 'type' => 'string', ), 'NetworkInterfaceId' => array( 'type' => 'string', ), 'NetworkInterfacePort' => array( 'type' => 'numeric', ), 'ChapEnabled' => array( 'type' => 'boolean', ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeWorkingStorageOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'DiskIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', ), ), 'WorkingStorageUsedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'WorkingStorageAllocatedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DisableGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListGatewaysOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Gateways' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'GatewayInfo', 'type' => 'object', 'properties' => array( 'GatewayARN' => array( 'type' => 'string', ), 'GatewayType' => array( 'type' => 'string', ), 'GatewayOperationalState' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListLocalDisksOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'Disks' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Disk', 'type' => 'object', 'properties' => array( 'DiskId' => array( 'type' => 'string', ), 'DiskPath' => array( 'type' => 'string', ), 'DiskNode' => array( 'type' => 'string', ), 'DiskSizeInBytes' => array( 'type' => 'numeric', ), 'DiskAllocationType' => array( 'type' => 'string', ), 'DiskAllocationResource' => array( 'type' => 'string', ), ), ), ), ), ), 'ListVolumeRecoveryPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeRecoveryPointInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeRecoveryPointInfo', 'type' => 'object', 'properties' => array( 'VolumeARN' => array( 'type' => 'string', ), 'VolumeSizeInBytes' => array( 'type' => 'numeric', ), 'VolumeUsageInBytes' => array( 'type' => 'numeric', ), 'VolumeRecoveryPointTime' => array( 'type' => 'string', ), ), ), ), ), ), 'ListVolumesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeInfo', 'type' => 'object', 'properties' => array( 'VolumeARN' => array( 'type' => 'string', ), 'VolumeType' => array( 'type' => 'string', ), ), ), ), ), ), 'RetrieveTapeArchiveOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'RetrieveTapeRecoveryPointOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ShutdownGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'StartGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateBandwidthRateLimitOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateChapCredentialsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TargetARN' => array( 'type' => 'string', 'location' => 'json', ), 'InitiatorName' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateGatewayInformationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateGatewaySoftwareNowOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateMaintenanceStartTimeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateSnapshotScheduleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeCachediSCSIVolumes' => array( 'result_key' => 'CachediSCSIVolumes', ), 'DescribeStorediSCSIVolumes' => array( 'result_key' => 'StorediSCSIVolumes', ), 'DescribeTapeArchives' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'TapeArchives', ), 'DescribeTapeRecoveryPoints' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'TapeRecoveryPointInfos', ), 'DescribeTapes' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'Tapes', ), 'DescribeVTLDevices' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'VTLDevices', ), 'ListGateways' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'Gateways', ), 'ListLocalDisks' => array( 'result_key' => 'Disks', ), 'ListVolumeRecoveryPoints' => array( 'result_key' => 'VolumeRecoveryPointInfos', ), 'ListVolumes' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'VolumeInfos', ), ), ), ); sdk-2.5.2/Aws/Sts/StsClient.php000064411532700161006750000001120512272324173013332 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/sts-%s.php' )) ->build(); // Attach a listener to prevent AssumeRoleWithWebIdentity requests from being signed $client->getEventDispatcher()->addListener('command.before_send', function(Event $event) { /** @var AbstractCommand $command */ $command = $event['command']; if ($command->getName() === 'AssumeRoleWithWebIdentity') { /** @var EventDispatcher $dispatcher */ $dispatcher = $command->getRequest()->getEventDispatcher(); foreach ($dispatcher->getListeners('request.before_send') as $listener) { if (is_array($listener) && $listener[0] instanceof SignatureListener) { $dispatcher->removeListener('request.before_send', $listener); break; } } } }); return $client; } /** * Creates a credentials object from the credential data return by an STS operation * * @param Model $result The result of an STS operation * * @return Credentials * @throws InvalidArgumentException if the result does not contain credential data */ public function createCredentials(Model $result) { if (!$result->hasKey('Credentials')) { throw new InvalidArgumentException('The modeled result provided contained no credentials.'); } return new Credentials( $result->getPath('Credentials/AccessKeyId'), $result->getPath('Credentials/SecretAccessKey'), $result->getPath('Credentials/SessionToken'), $result->getPath('Credentials/Expiration') ); } } sdk-2.5.2/Aws/Sts/Exception/ExpiredTokenException.php000064411532700161006750000000150012272324173017635 0ustar '2011-06-15', 'endpointPrefix' => 'sts', 'serviceFullName' => 'AWS Security Token Service', 'serviceAbbreviation' => 'AWS STS', 'serviceType' => 'query', 'globalEndpoint' => 'sts.amazonaws.com', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Sts', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AssumeRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssumeRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssumeRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'RoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), 'RoleSessionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 2, 'maxLength' => 32, ), 'Policy' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2048, ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 3600, ), 'ExternalId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 2, 'maxLength' => 96, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because the policy document was too large. The error message describes how big the policy document is, in packed form, as a percentage of what the API allows.', 'class' => 'PackedPolicyTooLargeException', ), ), ), 'AssumeRoleWithSAML' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssumeRoleWithSAMLResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssumeRoleWithSAML', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'RoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), 'PrincipalArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), 'SAMLAssertion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 50000, ), 'Policy' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2048, ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 129600, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because the policy document was too large. The error message describes how big the policy document is, in packed form, as a percentage of what the API allows.', 'class' => 'PackedPolicyTooLargeException', ), array( 'reason' => 'The identity provider (IdP) reported that authentication failed. This might be because the claim is invalid. If this error is returned for the AssumeRoleWithWebIdentity operation, it can also mean that the claim has expired or has been explicitly revoked.', 'class' => 'IDPRejectedClaimException', ), array( 'reason' => 'The web identity token that was passed could not be validated by AWS. Get a new identity token from the identity provider and then retry the request.', 'class' => 'InvalidIdentityTokenException', ), array( 'reason' => 'The web identity token that was passed is expired or is not valid. Get a new identity token from the identity provider and then retry the request.', 'class' => 'ExpiredTokenException', ), ), ), 'AssumeRoleWithWebIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssumeRoleWithWebIdentityResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssumeRoleWithWebIdentity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'RoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), 'RoleSessionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 2, 'maxLength' => 32, ), 'WebIdentityToken' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 2048, ), 'ProviderId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 2048, ), 'Policy' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2048, ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 129600, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because the policy document was too large. The error message describes how big the policy document is, in packed form, as a percentage of what the API allows.', 'class' => 'PackedPolicyTooLargeException', ), array( 'reason' => 'The identity provider (IdP) reported that authentication failed. This might be because the claim is invalid. If this error is returned for the AssumeRoleWithWebIdentity operation, it can also mean that the claim has expired or has been explicitly revoked.', 'class' => 'IDPRejectedClaimException', ), array( 'reason' => 'The request could not be fulfilled because the non-AWS identity provider (IDP) that was asked to verify the incoming identity token could not be reached. This is often a transient error caused by network conditions. Retry the request a limited number of times so that you don\'t exceed the request rate. If the error persists, the non-AWS identity provider might be down or not responding.', 'class' => 'IDPCommunicationErrorException', ), array( 'reason' => 'The web identity token that was passed could not be validated by AWS. Get a new identity token from the identity provider and then retry the request.', 'class' => 'InvalidIdentityTokenException', ), array( 'reason' => 'The web identity token that was passed is expired or is not valid. Get a new identity token from the identity provider and then retry the request.', 'class' => 'ExpiredTokenException', ), ), ), 'DecodeAuthorizationMessage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DecodeAuthorizationMessageResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DecodeAuthorizationMessage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'EncodedMessage' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 10240, ), ), 'errorResponses' => array( array( 'reason' => 'The error returned if the message passed to DecodeAuthorizationMessage was invalid. This can happen if the token contains invalid characters, such as linebreaks.', 'class' => 'InvalidAuthorizationMessageException', ), ), ), 'GetFederationToken' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetFederationTokenResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetFederationToken', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 2, 'maxLength' => 32, ), 'Policy' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2048, ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 129600, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because the policy document was too large. The error message describes how big the policy document is, in packed form, as a percentage of what the API allows.', 'class' => 'PackedPolicyTooLargeException', ), ), ), 'GetSessionToken' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSessionTokenResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSessionToken', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 129600, ), 'SerialNumber' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), 'TokenCode' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), ), ), ), 'models' => array( 'AssumeRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), 'AssumedRoleUser' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AssumedRoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), ), ), 'PackedPolicySize' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'AssumeRoleWithSAMLResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), 'AssumedRoleUser' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AssumedRoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), ), ), 'PackedPolicySize' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'AssumeRoleWithWebIdentityResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), 'SubjectFromWebIdentityToken' => array( 'type' => 'string', 'location' => 'xml', ), 'AssumedRoleUser' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AssumedRoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), ), ), 'PackedPolicySize' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'DecodeAuthorizationMessageResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DecodedMessage' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetFederationTokenResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), 'FederatedUser' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'FederatedUserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), ), ), 'PackedPolicySize' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'GetSessionTokenResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), ), ), ), ); sdk-2.5.2/Aws/Support/SupportClient.php000064411532700161006750000001070412272324173015143 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/support-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } sdk-2.5.2/Aws/Support/Exception/CaseCreationLimitExceededException.php000064411532700161006750000000141212272324173023127 0ustar '2013-04-15', 'endpointPrefix' => 'support', 'serviceFullName' => 'AWS Support', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'AWSSupport_20130415.', 'signatureVersion' => 'v4', 'namespace' => 'Support', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'support.us-east-1.amazonaws.com', ), ), 'operations' => array( 'AddCommunicationToCase' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddCommunicationToCaseResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.AddCommunicationToCase', ), 'caseId' => array( 'type' => 'string', 'location' => 'json', ), 'communicationBody' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 8000, ), 'ccEmailAddresses' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 10, 'items' => array( 'name' => 'CcEmailAddress', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when the CaseId requested could not be located.', 'class' => 'CaseIdNotFoundException', ), ), ), 'CreateCase' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateCaseResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.CreateCase', ), 'subject' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'serviceCode' => array( 'type' => 'string', 'location' => 'json', ), 'severityCode' => array( 'type' => 'string', 'location' => 'json', ), 'categoryCode' => array( 'type' => 'string', 'location' => 'json', ), 'communicationBody' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 8000, ), 'ccEmailAddresses' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 10, 'items' => array( 'name' => 'CcEmailAddress', 'type' => 'string', ), ), 'language' => array( 'type' => 'string', 'location' => 'json', ), 'issueType' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when you have exceeded the case creation limit for an account.', 'class' => 'CaseCreationLimitExceededException', ), ), ), 'DescribeCases' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCasesResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeCases', ), 'caseIdList' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 100, 'items' => array( 'name' => 'CaseId', 'type' => 'string', ), ), 'displayId' => array( 'type' => 'string', 'location' => 'json', ), 'afterTime' => array( 'type' => 'string', 'location' => 'json', ), 'beforeTime' => array( 'type' => 'string', 'location' => 'json', ), 'includeResolvedCases' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'nextToken' => array( 'type' => 'string', 'location' => 'json', ), 'maxResults' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 10, 'maximum' => 100, ), 'language' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when the CaseId requested could not be located.', 'class' => 'CaseIdNotFoundException', ), ), ), 'DescribeCommunications' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCommunicationsResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeCommunications', ), 'caseId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'beforeTime' => array( 'type' => 'string', 'location' => 'json', ), 'afterTime' => array( 'type' => 'string', 'location' => 'json', ), 'nextToken' => array( 'type' => 'string', 'location' => 'json', ), 'maxResults' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 10, 'maximum' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when the CaseId requested could not be located.', 'class' => 'CaseIdNotFoundException', ), ), ), 'DescribeServices' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeServicesResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeServices', ), 'serviceCodeList' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 100, 'items' => array( 'name' => 'ServiceCode', 'type' => 'string', ), ), 'language' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeSeverityLevels' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeSeverityLevelsResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeSeverityLevels', ), 'language' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTrustedAdvisorCheckRefreshStatuses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrustedAdvisorCheckRefreshStatusesResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeTrustedAdvisorCheckRefreshStatuses', ), 'checkIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTrustedAdvisorCheckResult' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrustedAdvisorCheckResultResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeTrustedAdvisorCheckResult', ), 'checkId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'language' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTrustedAdvisorCheckSummaries' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrustedAdvisorCheckSummariesResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeTrustedAdvisorCheckSummaries', ), 'checkIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTrustedAdvisorChecks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrustedAdvisorChecksResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeTrustedAdvisorChecks', ), 'language' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'RefreshTrustedAdvisorCheck' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RefreshTrustedAdvisorCheckResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.RefreshTrustedAdvisorCheck', ), 'checkId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'ResolveCase' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ResolveCaseResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.ResolveCase', ), 'caseId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when the CaseId requested could not be located.', 'class' => 'CaseIdNotFoundException', ), ), ), ), 'models' => array( 'AddCommunicationToCaseResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'result' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'CreateCaseResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'caseId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeCasesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'cases' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'CaseDetails', 'type' => 'object', 'properties' => array( 'caseId' => array( 'type' => 'string', ), 'displayId' => array( 'type' => 'string', ), 'subject' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'serviceCode' => array( 'type' => 'string', ), 'categoryCode' => array( 'type' => 'string', ), 'severityCode' => array( 'type' => 'string', ), 'submittedBy' => array( 'type' => 'string', ), 'timeCreated' => array( 'type' => 'string', ), 'recentCommunications' => array( 'type' => 'object', 'properties' => array( 'communications' => array( 'type' => 'array', 'items' => array( 'name' => 'Communication', 'type' => 'object', 'properties' => array( 'caseId' => array( 'type' => 'string', ), 'body' => array( 'type' => 'string', ), 'submittedBy' => array( 'type' => 'string', ), 'timeCreated' => array( 'type' => 'string', ), ), ), ), 'nextToken' => array( 'type' => 'string', ), ), ), 'ccEmailAddresses' => array( 'type' => 'array', 'items' => array( 'name' => 'CcEmailAddress', 'type' => 'string', ), ), 'language' => array( 'type' => 'string', ), ), ), ), 'nextToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeCommunicationsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'communications' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Communication', 'type' => 'object', 'properties' => array( 'caseId' => array( 'type' => 'string', ), 'body' => array( 'type' => 'string', ), 'submittedBy' => array( 'type' => 'string', ), 'timeCreated' => array( 'type' => 'string', ), ), ), ), 'nextToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeServicesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'services' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Service', 'type' => 'object', 'properties' => array( 'code' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'categories' => array( 'type' => 'array', 'items' => array( 'name' => 'Category', 'type' => 'object', 'properties' => array( 'code' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeSeverityLevelsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'severityLevels' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'SeverityLevel', 'type' => 'object', 'properties' => array( 'code' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeTrustedAdvisorCheckRefreshStatusesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'statuses' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TrustedAdvisorCheckRefreshStatus', 'type' => 'object', 'properties' => array( 'checkId' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'millisUntilNextRefreshable' => array( 'type' => 'numeric', ), ), ), ), ), ), 'DescribeTrustedAdvisorCheckResultResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'result' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'checkId' => array( 'type' => 'string', ), 'timestamp' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'resourcesSummary' => array( 'type' => 'object', 'properties' => array( 'resourcesProcessed' => array( 'type' => 'numeric', ), 'resourcesFlagged' => array( 'type' => 'numeric', ), 'resourcesIgnored' => array( 'type' => 'numeric', ), 'resourcesSuppressed' => array( 'type' => 'numeric', ), ), ), 'categorySpecificSummary' => array( 'type' => 'object', 'properties' => array( 'costOptimizing' => array( 'type' => 'object', 'properties' => array( 'estimatedMonthlySavings' => array( 'type' => 'numeric', ), 'estimatedPercentMonthlySavings' => array( 'type' => 'numeric', ), ), ), ), ), 'flaggedResources' => array( 'type' => 'array', 'items' => array( 'name' => 'TrustedAdvisorResourceDetail', 'type' => 'object', 'properties' => array( 'status' => array( 'type' => 'string', ), 'region' => array( 'type' => 'string', ), 'resourceId' => array( 'type' => 'string', ), 'isSuppressed' => array( 'type' => 'boolean', ), 'metadata' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeTrustedAdvisorCheckSummariesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'summaries' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TrustedAdvisorCheckSummary', 'type' => 'object', 'properties' => array( 'checkId' => array( 'type' => 'string', ), 'timestamp' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'hasFlaggedResources' => array( 'type' => 'boolean', ), 'resourcesSummary' => array( 'type' => 'object', 'properties' => array( 'resourcesProcessed' => array( 'type' => 'numeric', ), 'resourcesFlagged' => array( 'type' => 'numeric', ), 'resourcesIgnored' => array( 'type' => 'numeric', ), 'resourcesSuppressed' => array( 'type' => 'numeric', ), ), ), 'categorySpecificSummary' => array( 'type' => 'object', 'properties' => array( 'costOptimizing' => array( 'type' => 'object', 'properties' => array( 'estimatedMonthlySavings' => array( 'type' => 'numeric', ), 'estimatedPercentMonthlySavings' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), ), ), 'DescribeTrustedAdvisorChecksResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'checks' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TrustedAdvisorCheckDescription', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'category' => array( 'type' => 'string', ), 'metadata' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), ), ), 'RefreshTrustedAdvisorCheckResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'status' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'checkId' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'millisUntilNextRefreshable' => array( 'type' => 'numeric', ), ), ), ), ), 'ResolveCaseResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'initialCaseStatus' => array( 'type' => 'string', 'location' => 'json', ), 'finalCaseStatus' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeCases' => array( 'token_param' => 'nextToken', 'token_key' => 'nextToken', 'limit_key' => 'maxResults', 'result_key' => 'cases', ), 'DescribeCommunications' => array( 'token_param' => 'nextToken', 'token_key' => 'nextToken', 'limit_key' => 'maxResults', 'result_key' => 'communications', ), 'DescribeServices' => array( 'result_key' => 'services', ), 'DescribeTrustedAdvisorCheckRefreshStatuses' => array( 'result_key' => 'statuses', ), 'DescribeTrustedAdvisorCheckSummaries' => array( 'result_key' => 'summaries', ), 'DescribeSeverityLevels' => array( 'result_key' => 'severityLevelsList', ), 'DescribeTrustedAdvisorChecks' => array( 'result_key' => 'checks', ), ), ), ); sdk-2.5.2/Aws/Swf/SwfClient.php000064411532700161006750000001432712272324173013316 0ustar setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/swf-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } sdk-2.5.2/Aws/Swf/Enum/ActivityTaskTimeoutType.php000064411532700161006750000000164212272324173017150 0ustar '2012-01-25', 'endpointPrefix' => 'swf', 'serviceFullName' => 'Amazon Simple Workflow Service', 'serviceAbbreviation' => 'Amazon SWF', 'serviceType' => 'json', 'jsonVersion' => '1.0', 'targetPrefix' => 'SimpleWorkflowService.', 'timestampFormat' => 'unixTimestamp', 'signatureVersion' => 'v4', 'namespace' => 'Swf', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'CountClosedWorkflowExecutions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionCount', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.CountClosedWorkflowExecutions', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'startTimeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'closeTimeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'executionFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'typeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), 'tagFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'tag' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'closeStatusFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'status' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'COMPLETED', 'FAILED', 'CANCELED', 'TERMINATED', 'CONTINUED_AS_NEW', 'TIMED_OUT', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'CountOpenWorkflowExecutions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionCount', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.CountOpenWorkflowExecutions', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'startTimeFilter' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'typeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), 'tagFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'tag' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'executionFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'CountPendingActivityTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PendingTaskCount', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.CountPendingActivityTasks', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'taskList' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'CountPendingDecisionTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PendingTaskCount', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.CountPendingDecisionTasks', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'taskList' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DeprecateActivityType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DeprecateActivityType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'activityType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the specified activity or workflow type was already deprecated.', 'class' => 'TypeDeprecatedException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DeprecateDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DeprecateDomain', ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the specified domain has been deprecated.', 'class' => 'DomainDeprecatedException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DeprecateWorkflowType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DeprecateWorkflowType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the specified activity or workflow type was already deprecated.', 'class' => 'TypeDeprecatedException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DescribeActivityType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivityTypeDetail', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DescribeActivityType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'activityType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DescribeDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DomainDetail', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DescribeDomain', ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DescribeWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionDetail', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DescribeWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'execution' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DescribeWorkflowType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowTypeDetail', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DescribeWorkflowType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'GetWorkflowExecutionHistory' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'History', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.GetWorkflowExecutionHistory', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'execution' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'ListActivityTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivityTypeInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListActivityTypes', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'registrationStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'enum' => array( 'REGISTERED', 'DEPRECATED', ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), ), ), 'ListClosedWorkflowExecutions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListClosedWorkflowExecutions', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'startTimeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'closeTimeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'executionFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'closeStatusFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'status' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'COMPLETED', 'FAILED', 'CANCELED', 'TERMINATED', 'CONTINUED_AS_NEW', 'TIMED_OUT', ), ), ), ), 'typeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), 'tagFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'tag' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'ListDomains' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DomainInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListDomains', ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'registrationStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'enum' => array( 'REGISTERED', 'DEPRECATED', ), ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'ListOpenWorkflowExecutions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListOpenWorkflowExecutions', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'startTimeFilter' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'typeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), 'tagFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'tag' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'executionFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'ListWorkflowTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowTypeInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListWorkflowTypes', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'registrationStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'enum' => array( 'REGISTERED', 'DEPRECATED', ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), ), ), 'PollForActivityTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivityTask', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.PollForActivityTask', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'taskList' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'identity' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), ), ), 'PollForDecisionTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DecisionTask', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.PollForDecisionTask', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'taskList' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'identity' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), ), ), 'RecordActivityTaskHeartbeat' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivityTaskStatus', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RecordActivityTaskHeartbeat', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'details' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RegisterActivityType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RegisterActivityType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 64, ), 'description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'defaultTaskStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultTaskHeartbeatTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultTaskList' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'defaultTaskScheduleToStartTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultTaskScheduleToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the type already exists in the specified domain. You will get this fault even if the existing type is in deprecated status. You can specify another version if the intent is to create a new distinct version of the type.', 'class' => 'TypeAlreadyExistsException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RegisterDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RegisterDomain', ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'workflowExecutionRetentionPeriodInDays' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 8, ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified domain already exists. You will get this fault even if the existing domain is in deprecated status.', 'class' => 'DomainAlreadyExistsException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RegisterWorkflowType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RegisterWorkflowType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 64, ), 'description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'defaultTaskStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultExecutionStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultTaskList' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'defaultChildPolicy' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the type already exists in the specified domain. You will get this fault even if the existing type is in deprecated status. You can specify another version if the intent is to create a new distinct version of the type.', 'class' => 'TypeAlreadyExistsException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RequestCancelWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RequestCancelWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RespondActivityTaskCanceled' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RespondActivityTaskCanceled', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'details' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RespondActivityTaskCompleted' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RespondActivityTaskCompleted', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'result' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RespondActivityTaskFailed' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RespondActivityTaskFailed', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'reason' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'details' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RespondDecisionTaskCompleted' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RespondDecisionTaskCompleted', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'decisions' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Decision', 'type' => 'object', 'properties' => array( 'decisionType' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'ScheduleActivityTask', 'RequestCancelActivityTask', 'CompleteWorkflowExecution', 'FailWorkflowExecution', 'CancelWorkflowExecution', 'ContinueAsNewWorkflowExecution', 'RecordMarker', 'StartTimer', 'CancelTimer', 'SignalExternalWorkflowExecution', 'RequestCancelExternalWorkflowExecution', 'StartChildWorkflowExecution', ), ), 'scheduleActivityTaskDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'activityId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), 'input' => array( 'type' => 'string', 'maxLength' => 32768, ), 'scheduleToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'scheduleToStartTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'startToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'heartbeatTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), ), ), 'requestCancelActivityTaskDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'activityId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'completeWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'failWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', 'maxLength' => 256, ), 'details' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'cancelWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'continueAsNewWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', 'maxLength' => 32768, ), 'executionStartToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'childPolicy' => array( 'type' => 'string', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), 'tagList' => array( 'type' => 'array', 'maxItems' => 5, 'items' => array( 'name' => 'Tag', 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), 'workflowTypeVersion' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'recordMarkerDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'details' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'startTimerDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), 'startToFireTimeout' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 8, ), ), ), 'cancelTimerDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'signalExternalWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'maxLength' => 64, ), 'signalName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'input' => array( 'type' => 'string', 'maxLength' => 32768, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'requestCancelExternalWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'maxLength' => 64, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'startChildWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowType' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), 'input' => array( 'type' => 'string', 'maxLength' => 32768, ), 'executionStartToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'childPolicy' => array( 'type' => 'string', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), 'tagList' => array( 'type' => 'array', 'maxItems' => 5, 'items' => array( 'name' => 'Tag', 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), ), ), ), 'executionContext' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'SignalWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.SignalWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 64, ), 'signalName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'input' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'StartWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Run', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.StartWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'taskList' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'input' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), 'executionStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'tagList' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 5, 'items' => array( 'name' => 'Tag', 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'childPolicy' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the specified activity or workflow type was already deprecated.', 'class' => 'TypeDeprecatedException', ), array( 'reason' => 'Returned by StartWorkflowExecution when an open execution with the same workflowId is already running in the specified domain.', 'class' => 'WorkflowExecutionAlreadyStartedException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'class' => 'DefaultUndefinedException', ), ), ), 'TerminateWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.TerminateWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 64, ), 'reason' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'details' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), 'childPolicy' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), ), 'models' => array( 'WorkflowExecutionCount' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'count' => array( 'type' => 'numeric', 'location' => 'json', ), 'truncated' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'PendingTaskCount' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'count' => array( 'type' => 'numeric', 'location' => 'json', ), 'truncated' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ActivityTypeDetail' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'typeInfo' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'creationDate' => array( 'type' => 'string', ), 'deprecationDate' => array( 'type' => 'string', ), ), ), 'configuration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'defaultTaskStartToCloseTimeout' => array( 'type' => 'string', ), 'defaultTaskHeartbeatTimeout' => array( 'type' => 'string', ), 'defaultTaskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'defaultTaskScheduleToStartTimeout' => array( 'type' => 'string', ), 'defaultTaskScheduleToCloseTimeout' => array( 'type' => 'string', ), ), ), ), ), 'DomainDetail' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'domainInfo' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), ), ), 'configuration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowExecutionRetentionPeriodInDays' => array( 'type' => 'string', ), ), ), ), ), 'WorkflowExecutionDetail' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'executionInfo' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'execution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'startTimestamp' => array( 'type' => 'string', ), 'closeTimestamp' => array( 'type' => 'string', ), 'executionStatus' => array( 'type' => 'string', ), 'closeStatus' => array( 'type' => 'string', ), 'parent' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'cancelRequested' => array( 'type' => 'boolean', ), ), ), 'executionConfiguration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'childPolicy' => array( 'type' => 'string', ), ), ), 'openCounts' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'openActivityTasks' => array( 'type' => 'numeric', ), 'openDecisionTasks' => array( 'type' => 'numeric', ), 'openTimers' => array( 'type' => 'numeric', ), 'openChildWorkflowExecutions' => array( 'type' => 'numeric', ), ), ), 'latestActivityTaskTimestamp' => array( 'type' => 'string', 'location' => 'json', ), 'latestExecutionContext' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'WorkflowTypeDetail' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'typeInfo' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'creationDate' => array( 'type' => 'string', ), 'deprecationDate' => array( 'type' => 'string', ), ), ), 'configuration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'defaultTaskStartToCloseTimeout' => array( 'type' => 'string', ), 'defaultExecutionStartToCloseTimeout' => array( 'type' => 'string', ), 'defaultTaskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'defaultChildPolicy' => array( 'type' => 'string', ), ), ), ), ), 'History' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'events' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'HistoryEvent', 'type' => 'object', 'properties' => array( 'eventTimestamp' => array( 'type' => 'string', ), 'eventType' => array( 'type' => 'string', ), 'eventId' => array( 'type' => 'numeric', ), 'workflowExecutionStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'continuedExecutionRunId' => array( 'type' => 'string', ), 'parentWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'parentInitiatedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'completeWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'failWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), ), ), 'workflowExecutionCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'cancelWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionContinuedAsNewEventAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'newExecutionRunId' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), ), ), 'continueAsNewWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionTerminatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), ), ), 'workflowExecutionCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'externalWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'externalInitiatedEventId' => array( 'type' => 'numeric', ), 'cause' => array( 'type' => 'string', ), ), ), 'decisionTaskScheduledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'startToCloseTimeout' => array( 'type' => 'string', ), ), ), 'decisionTaskStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'identity' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), ), ), 'decisionTaskCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'executionContext' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'decisionTaskTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskScheduledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'activityId' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'control' => array( 'type' => 'string', ), 'scheduleToStartTimeout' => array( 'type' => 'string', ), 'scheduleToCloseTimeout' => array( 'type' => 'string', ), 'startToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'heartbeatTimeout' => array( 'type' => 'string', ), ), ), 'activityTaskStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'identity' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), 'details' => array( 'type' => 'string', ), ), ), 'activityTaskCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), 'latestCancelRequestedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'activityId' => array( 'type' => 'string', ), ), ), 'workflowExecutionSignaledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'signalName' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'externalWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'externalInitiatedEventId' => array( 'type' => 'numeric', ), ), ), 'markerRecordedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'recordMarkerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'timerStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'control' => array( 'type' => 'string', ), 'startToFireTimeout' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'timerFiredEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'timerCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'startedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startChildWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'control' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'childPolicy' => array( 'type' => 'string', ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), ), ), 'childWorkflowExecutionStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'result' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'timeoutType' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'details' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionTerminatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'signalExternalWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'signalName' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'externalWorkflowExecutionSignaledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'signalExternalWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'externalWorkflowExecutionCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'requestCancelExternalWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'requestCancelExternalWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'scheduleActivityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'activityId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'requestCancelActivityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startTimerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'cancelTimerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startChildWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'cause' => array( 'type' => 'string', ), 'workflowId' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ActivityTypeInfos' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'typeInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ActivityTypeInfo', 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'creationDate' => array( 'type' => 'string', ), 'deprecationDate' => array( 'type' => 'string', ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'WorkflowExecutionInfos' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'executionInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'WorkflowExecutionInfo', 'type' => 'object', 'properties' => array( 'execution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'startTimestamp' => array( 'type' => 'string', ), 'closeTimestamp' => array( 'type' => 'string', ), 'executionStatus' => array( 'type' => 'string', ), 'closeStatus' => array( 'type' => 'string', ), 'parent' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'cancelRequested' => array( 'type' => 'boolean', ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DomainInfos' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'domainInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DomainInfo', 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'WorkflowTypeInfos' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'typeInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'WorkflowTypeInfo', 'type' => 'object', 'properties' => array( 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'creationDate' => array( 'type' => 'string', ), 'deprecationDate' => array( 'type' => 'string', ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ActivityTask' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'taskToken' => array( 'type' => 'string', 'location' => 'json', ), 'activityId' => array( 'type' => 'string', 'location' => 'json', ), 'startedEventId' => array( 'type' => 'numeric', 'location' => 'json', ), 'workflowExecution' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'activityType' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'input' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DecisionTask' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'taskToken' => array( 'type' => 'string', 'location' => 'json', ), 'startedEventId' => array( 'type' => 'numeric', 'location' => 'json', ), 'workflowExecution' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'events' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'HistoryEvent', 'type' => 'object', 'properties' => array( 'eventTimestamp' => array( 'type' => 'string', ), 'eventType' => array( 'type' => 'string', ), 'eventId' => array( 'type' => 'numeric', ), 'workflowExecutionStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'continuedExecutionRunId' => array( 'type' => 'string', ), 'parentWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'parentInitiatedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'completeWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'failWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), ), ), 'workflowExecutionCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'cancelWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionContinuedAsNewEventAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'newExecutionRunId' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), ), ), 'continueAsNewWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionTerminatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), ), ), 'workflowExecutionCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'externalWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'externalInitiatedEventId' => array( 'type' => 'numeric', ), 'cause' => array( 'type' => 'string', ), ), ), 'decisionTaskScheduledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'startToCloseTimeout' => array( 'type' => 'string', ), ), ), 'decisionTaskStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'identity' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), ), ), 'decisionTaskCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'executionContext' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'decisionTaskTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskScheduledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'activityId' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'control' => array( 'type' => 'string', ), 'scheduleToStartTimeout' => array( 'type' => 'string', ), 'scheduleToCloseTimeout' => array( 'type' => 'string', ), 'startToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'heartbeatTimeout' => array( 'type' => 'string', ), ), ), 'activityTaskStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'identity' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), 'details' => array( 'type' => 'string', ), ), ), 'activityTaskCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), 'latestCancelRequestedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'activityId' => array( 'type' => 'string', ), ), ), 'workflowExecutionSignaledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'signalName' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'externalWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'externalInitiatedEventId' => array( 'type' => 'numeric', ), ), ), 'markerRecordedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'recordMarkerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'timerStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'control' => array( 'type' => 'string', ), 'startToFireTimeout' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'timerFiredEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'timerCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'startedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startChildWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'control' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'childPolicy' => array( 'type' => 'string', ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), ), ), 'childWorkflowExecutionStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'result' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'timeoutType' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'details' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionTerminatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'signalExternalWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'signalName' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'externalWorkflowExecutionSignaledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'signalExternalWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'externalWorkflowExecutionCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'requestCancelExternalWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'requestCancelExternalWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'scheduleActivityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'activityId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'requestCancelActivityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startTimerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'cancelTimerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startChildWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'cause' => array( 'type' => 'string', ), 'workflowId' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), 'previousStartedEventId' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'ActivityTaskStatus' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'cancelRequested' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'Run' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'runId' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'GetWorkflowExecutionHistory' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'events', ), 'ListActivityTypes' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'typeInfos', ), 'ListClosedWorkflowExecutions' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'executionInfos', ), 'ListDomains' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'domainInfos', ), 'ListOpenWorkflowExecutions' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'executionInfos', ), 'ListWorkflowTypes' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'typeInfos', ), 'PollForDecisionTask' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'events', ), ), ), ); sdk-2.5.2/aws.phar000066611532700161006750003367753712272324173011120 0ustar 4+9a:1:{s:4:"link";s:32:"http://aws.amazon.com/sdkforphp2";}%Aws/AutoScaling/AutoScalingClient.phpoYRo4VtL'Aws/AutoScaling/Enum/LifecycleState.phpYR2Aws/AutoScaling/Enum/ScalingActivityStatusCode.phpYRr<4Aws/AutoScaling/Exception/AlreadyExistsException.phpYR9]2Aws/AutoScaling/Exception/AutoScalingException.phpYR_ 7Aws/AutoScaling/Exception/InvalidNextTokenException.phpYRC4Aws/AutoScaling/Exception/LimitExceededException.php!YR!"Fζ4Aws/AutoScaling/Exception/ResourceInUseException.php-YR-7'`@Aws/AutoScaling/Exception/ScalingActivityInProgressException.php1YR1j@84Aws/AutoScaling/Resources/autoscaling-2011-01-01.phpߜYRߜ{}+Aws/CloudFormation/CloudFormationClient.phpYRD󙰶&Aws/CloudFormation/Enum/Capability.php YR Q%Aws/CloudFormation/Enum/OnFailure.php>YR>`7㧶*Aws/CloudFormation/Enum/ResourceStatus.phpYR?# 'Aws/CloudFormation/Enum/StackStatus.phpYRX墕7Aws/CloudFormation/Exception/AlreadyExistsException.phpYRa8Aws/CloudFormation/Exception/CloudFormationException.phpYR]sBAws/CloudFormation/Exception/InsufficientCapabilitiesException.php8YR8F[7Aws/CloudFormation/Exception/LimitExceededException.phpYR:Aws/CloudFormation/Resources/cloudformation-2010-05-15.phpYR Bb#Aws/CloudFront/CloudFrontClient.php0YR0&Aws/CloudFront/CloudFrontSignature.phpYR.g&*Aws/CloudFront/Enum/GeoRestrictionType.phpHYRHJƶ%Aws/CloudFront/Enum/ItemSelection.php2YR2Aws/CloudFront/Enum/Method.phpYR\X,Aws/CloudFront/Enum/OriginProtocolPolicy.php9YR9GL"Aws/CloudFront/Enum/PriceClass.phpcYRc@,Aws/CloudFront/Enum/ViewerProtocolPolicy.php5YR5[;Ͷ2Aws/CloudFront/Exception/AccessDeniedException.phpYRy!3Aws/CloudFront/Exception/BatchTooLargeException.phpYRu0Aws/CloudFront/Exception/CloudFrontException.phpYRk5Aws/CloudFront/Exception/InvalidArgumentException.phpYR$UB>Aws/CloudFront/Exception/InvalidDefaultRootObjectException.phpYR26Aws/CloudFront/Exception/InvalidErrorCodeException.php YR ݶ;Aws/CloudFront/Exception/InvalidForwardCookiesException.phpYR%DAws/CloudFront/Exception/InvalidGeoRestrictionParameterException.php'YR'4(t;Aws/CloudFront/Exception/InvalidIfMatchVersionException.phpYRo9Aws/CloudFront/Exception/InvalidLocationCodeException.phpYRJ)rAAws/CloudFront/Exception/InvalidOriginAccessIdentityException.phpYRi33Aws/CloudFront/Exception/InvalidOriginException.phpYRG 59Aws/CloudFront/Exception/InvalidRelativePathException.phpYRݶ=Aws/CloudFront/Exception/InvalidRequiredProtocolException.phpzYRz{N׶9Aws/CloudFront/Exception/InvalidResponseCodeException.phpYRAq>Aws/CloudFront/Exception/InvalidViewerCertificateException.phpYRB1Aws/CloudFront/Exception/MissingBodyException.phpYRruNJAws/CloudFront/Exception/NoSuchCloudFrontOriginAccessIdentityException.phpYR Au8Aws/CloudFront/Exception/NoSuchDistributionException.phpYR18Aws/CloudFront/Exception/NoSuchInvalidationException.phpYRcj2Aws/CloudFront/Exception/NoSuchOriginException.phpYR`RAAws/CloudFront/Exception/NoSuchStreamingDistributionException.phpYRf08Aws/CloudFront/Exception/PreconditionFailedException.phpYR%gڶHAws/CloudFront/Exception/StreamingDistributionAlreadyExistsException.php/YR/FAws/CloudFront/Exception/StreamingDistributionNotDisabledException.php+YR+ g;Aws/CloudFront/Exception/TooManyCacheBehaviorsException.phpYR7;;9Aws/CloudFront/Exception/TooManyCertificatesException.phpYR8пMAws/CloudFront/Exception/TooManyCloudFrontOriginAccessIdentitiesException.php@YR@{iCAws/CloudFront/Exception/TooManyCookieNamesInWhiteListException.php*YR*~?Aws/CloudFront/Exception/TooManyDistributionCNAMEsException.php YR dRx:Aws/CloudFront/Exception/TooManyDistributionsException.php"YR".;DAws/CloudFront/Exception/TooManyInvalidationsInProgressException.php@YR@K暶4Aws/CloudFront/Exception/TooManyOriginsException.phpYRƶHAws/CloudFront/Exception/TooManyStreamingDistributionCNAMEsException.php/YR/6@pCAws/CloudFront/Exception/TooManyStreamingDistributionsException.php5YR5o;Aws/CloudFront/Exception/TooManyTrustedSignersException.phpYRs?Aws/CloudFront/Exception/TrustedSignerDoesNotExistException.phpYRG2Aws/CloudFront/Resources/cloudfront-2012-05-05.php "YR "{.ȶ2Aws/CloudFront/Resources/cloudfront-2013-11-11.phpYRE>%Aws/CloudSearch/CloudSearchClient.phpYR'Aws/CloudSearch/Enum/IndexFieldType.php3YR3Ŷ$Aws/CloudSearch/Enum/OptionState.php]YR]'+Aws/CloudSearch/Enum/SearchInstanceType.phpYR+Aws/CloudSearch/Enum/SourceDataFunction.php>YR>짶+Aws/CloudSearch/Exception/BaseException.phpYR12Aws/CloudSearch/Exception/CloudSearchException.phpYRnC&/Aws/CloudSearch/Exception/InternalException.php?YR?g2Aws/CloudSearch/Exception/InvalidTypeException.phpYRe4Aws/CloudSearch/Exception/LimitExceededException.phpYR7Aws/CloudSearch/Exception/ResourceNotFoundException.phpYRyѶ4Aws/CloudSearch/Resources/cloudsearch-2011-02-01.phpYRu #Aws/CloudTrail/CloudTrailClient.php YR A0Aws/CloudTrail/Exception/CloudTrailException.phpYR6@Aws/CloudTrail/Exception/InsufficientS3BucketPolicyException.phpYR{KI@Aws/CloudTrail/Exception/InsufficientSnsTopicPolicyException.phpYRG3Aws/CloudTrail/Exception/InternalErrorException.phpYR/5¶9Aws/CloudTrail/Exception/InvalidS3BucketNameException.php YR 'd5Aws/CloudTrail/Exception/InvalidS3PrefixException.phpYR)_9Aws/CloudTrail/Exception/InvalidSnsTopicNameException.php YR ˉI6Aws/CloudTrail/Exception/InvalidTrailNameException.phpYRdfCAws/CloudTrail/Exception/MaximumNumberOfTrailsExceededException.phpYR3[:Aws/CloudTrail/Exception/S3BucketDoesNotExistException.php YR b4e8Aws/CloudTrail/Exception/TrailAlreadyExistsException.phpYR Y3Aws/CloudTrail/Exception/TrailNotFoundException.phpYR[D6Aws/CloudTrail/Exception/TrailNotProvidedException.phpYRN"Aws/CloudTrail/LogFileIterator.php;,YR;,eYǶ Aws/CloudTrail/LogFileReader.phpYRt@$Aws/CloudTrail/LogRecordIterator.phpYRt2Aws/CloudTrail/Resources/cloudtrail-2013-11-01.php1bYR1bkԎ#Aws/CloudWatch/CloudWatchClient.php!YR!J'{*Aws/CloudWatch/Enum/ComparisonOperator.phpYR_m¶'Aws/CloudWatch/Enum/HistoryItemType.php`YR` "Aws/CloudWatch/Enum/StateValue.php<YR<O!Aws/CloudWatch/Enum/Statistic.phpsYRsɶAws/CloudWatch/Enum/Unit.phpYRJ0Aws/CloudWatch/Exception/CloudWatchException.phpYR|?!˶5Aws/CloudWatch/Exception/InternalServiceException.php!YR!_3Aws/CloudWatch/Exception/InvalidFormatException.phpYRy6Aws/CloudWatch/Exception/InvalidNextTokenException.phpYRdP,AAws/CloudWatch/Exception/InvalidParameterCombinationException.phpYR{;Aws/CloudWatch/Exception/InvalidParameterValueException.phpYRz3Aws/CloudWatch/Exception/LimitExceededException.phpYR- y>Aws/CloudWatch/Exception/MissingRequiredParameterException.phpYR#It6Aws/CloudWatch/Exception/ResourceNotFoundException.phpYRx2Aws/CloudWatch/Resources/cloudwatch-2010-08-01.phpYR4hܶAws/Common/Aws.phpVYRVƜ$Aws/Common/Client/AbstractClient.php %YR %Q(Aws/Common/Client/AwsClientInterface.php YR w#Aws/Common/Client/ClientBuilder.phpn>YRn>@#Aws/Common/Client/DefaultClient.php YR *8/Aws/Common/Client/ExpiredCredentialsChecker.php YR n,Aws/Common/Client/ThrottlingErrorChecker.phpZ YRZ ^t>,(Aws/Common/Client/UploadBodyListener.php; YR; V('Aws/Common/Client/UserAgentListener.phpYR1=<&Aws/Common/Command/AwsQueryVisitor.phpYRk"Aws/Common/Command/JsonCommand.phpUYRUi#Aws/Common/Command/QueryCommand.phpYR1Aws/Common/Command/XmlResponseLocationVisitor.phpcYRcT7Aws/Common/Credentials/AbstractCredentialsDecorator.php YR ~(9Aws/Common/Credentials/AbstractRefreshableCredentials.phpYR뵶/Aws/Common/Credentials/CacheableCredentials.php YR =&Aws/Common/Credentials/Credentials.phpT!YRT!ur/Aws/Common/Credentials/CredentialsInterface.php YR /@Aws/Common/Credentials/RefreshableInstanceProfileCredentials.php5YR5"EE!Aws/Common/Enum/ClientOptions.phpYRůAws/Common/Enum/DateFormat.phpYRf:oCAws/Common/Enum/Region.phpYR zAws/Common/Enum/Size.phpYRv06Aws/Common/Enum/Time.phpEYRE!uAws/Common/Enum/UaString.phpGYRG6X*Aws/Common/Enum.phpYRd|K.Aws/Common/Exception/AwsExceptionInterface.phpYR(/Aws/Common/Exception/BadMethodCallException.phpYRX(Aws/Common/Exception/DomainException.phpYRe2Aws/Common/Exception/ExceptionFactoryInterface.phpzYRzV a׶*Aws/Common/Exception/ExceptionListener.phpYR<Aws/Common/Exception/InstanceProfileCredentialsException.phpYR1Aws/Common/Exception/InvalidArgumentException.php!YR!/- 'Aws/Common/Exception/LogicException.phpYRXg1Aws/Common/Exception/MultipartUploadException.phpgYRgO̓2Aws/Common/Exception/NamespaceExceptionFactory.php YR 0-Aws/Common/Exception/OutOfBoundsException.phpYR$}X̶*Aws/Common/Exception/OverflowException.php YR ׶;Aws/Common/Exception/Parser/AbstractJsonExceptionParser.phpYR99Aws/Common/Exception/Parser/DefaultXmlExceptionParser.php YR W`g8Aws/Common/Exception/Parser/ExceptionParserInterface.phpqYRq78Aws/Common/Exception/Parser/JsonQueryExceptionParser.phpYRٳ7Aws/Common/Exception/Parser/JsonRestExceptionParser.phpYR<Aws/Common/Exception/RequiredExtensionNotLoadedException.php3YR3})Aws/Common/Exception/RuntimeException.php YR \1Aws/Common/Exception/ServiceResponseException.phpIYRI~׵&*Aws/Common/Exception/TransferException.phpYR%dҶ1Aws/Common/Exception/UnexpectedValueException.php!YR! )$Aws/Common/Facade/facade-classes.phpYR6Aws/Common/Facade/Facade.phpYR%Aws/Common/Facade/FacadeInterface.phpLYRLHgzaAws/Common/Hash/ChunkHash.phpPYRP(׶&Aws/Common/Hash/ChunkHashInterface.phpYRobsAws/Common/Hash/HashUtils.phpYRI滶Aws/Common/Hash/TreeHash.phpYRwնAws/Common/HostNameUtils.php YR RR6Aws/Common/InstanceMetadata/InstanceMetadataClient.phpYRsXa7Aws/Common/InstanceMetadata/Waiter/ServiceAvailable.phpYR`=+Aws/Common/Iterator/AwsResourceIterator.phpYR@2Aws/Common/Iterator/AwsResourceIteratorFactory.phpYRleǶ5Aws/Common/Model/MultipartUpload/AbstractTransfer.php=YR= S巶:Aws/Common/Model/MultipartUpload/AbstractTransferState.php5YR5 u:Aws/Common/Model/MultipartUpload/AbstractUploadBuilder.phpYReT5Aws/Common/Model/MultipartUpload/AbstractUploadId.phpYRn$Ŷ7Aws/Common/Model/MultipartUpload/AbstractUploadPart.php YR g $6Aws/Common/Model/MultipartUpload/TransferInterface.phpOYRO\;Aws/Common/Model/MultipartUpload/TransferStateInterface.php YR ;6Aws/Common/Model/MultipartUpload/UploadIdInterface.phpiYRiv8Aws/Common/Model/MultipartUpload/UploadPartInterface.phpYRsգ#Aws/Common/Resources/aws-config.phpYRe,J$Aws/Common/Resources/sdk1-config.php(YR(%*Aws/Common/Signature/AbstractSignature.phpYR3Aws/Common/Signature/EndpointSignatureInterface.phpYR?M+Aws/Common/Signature/SignatureInterface.php%YR%߶*Aws/Common/Signature/SignatureListener.phpYR,)$Aws/Common/Signature/SignatureV2.php5YR5&FŶ)Aws/Common/Signature/SignatureV3Https.phpAYRA9 $Aws/Common/Signature/SignatureV4.php(YR(:,Aws/Common/Waiter/AbstractResourceWaiter.php:YR:G5H$Aws/Common/Waiter/AbstractWaiter.phpYR-&$Aws/Common/Waiter/CallableWaiter.phpHYRH ,Aws/Common/Waiter/CompositeWaiterFactory.phpYR y|*Aws/Common/Waiter/ConfigResourceWaiter.phptYRtg]-Aws/Common/Waiter/ResourceWaiterInterface.phpYR`Y(Aws/Common/Waiter/WaiterClassFactory.php YR q"Aws/Common/Waiter/WaiterConfig.php7YR7 )Aws/Common/Waiter/WaiterConfigFactory.php YR ׶,Aws/Common/Waiter/WaiterFactoryInterface.phpjYRj.I%Aws/Common/Waiter/WaiterInterface.phpEYRETfz'Aws/DataPipeline/DataPipelineClient.phpYRw6d$Aws/DataPipeline/Enum/WorkStatus.php4YR4.4Aws/DataPipeline/Exception/DataPipelineException.phpYRL̾5<Aws/DataPipeline/Exception/InternalServiceErrorException.phpYR46Aws/DataPipeline/Exception/InvalidRequestException.phpYR;7Aws/DataPipeline/Exception/PipelineDeletedException.phpYRK'8Aws/DataPipeline/Exception/PipelineNotFoundException.php(YR(П4Aws/DataPipeline/Exception/TaskNotFoundException.phpYRbl6Aws/DataPipeline/Resources/datapipeline-2012-10-29.phpYR))Aws/DirectConnect/DirectConnectClient.phpYRRݠ*Aws/DirectConnect/Enum/ConnectionState.phpYR+,Aws/DirectConnect/Enum/InterconnectState.phpYRk\$Aws/DirectConnect/Enum/StepState.phpYRV^0Aws/DirectConnect/Enum/VirtualInterfaceState.phpYRO/<Aws/DirectConnect/Exception/DirectConnectClientException.php7YR7…b]6Aws/DirectConnect/Exception/DirectConnectException.phpYR+h<Aws/DirectConnect/Exception/DirectConnectServerException.php=YR=8Aws/DirectConnect/Resources/directconnect-2012-10-25.phpYR[&"Aws/DynamoDb/Crc32ErrorChecker.phpYR۷!Aws/DynamoDb/DynamoDbClient.php@#YR@#8<;%Aws/DynamoDb/Enum/AttributeAction.php,YR,M#Aws/DynamoDb/Enum/AttributeType.phpYR.T(Aws/DynamoDb/Enum/ComparisonOperator.phpDYRD1D϶!Aws/DynamoDb/Enum/IndexStatus.phpYYRY Aws/DynamoDb/Enum/KeyType.phpYR3 b$Aws/DynamoDb/Enum/ProjectionType.php9YR91VU,Aws/DynamoDb/Enum/ReturnConsumedCapacity.phpBYRBeZ `1Aws/DynamoDb/Enum/ReturnItemCollectionMetrics.php+YR+ݿD!Aws/DynamoDb/Enum/ReturnValue.php~YR~ &)Aws/DynamoDb/Enum/ScalarAttributeType.php"YR"u'#{Aws/DynamoDb/Enum/Select.phpYR֨!Aws/DynamoDb/Enum/TableStatus.phpYYRY8ƶAws/DynamoDb/Enum/Type.phpYRK4(0Aws/DynamoDb/Exception/AccessDeniedException.phpYRfՏ:Aws/DynamoDb/Exception/ConditionalCheckFailedException.phpYR2,Aws/DynamoDb/Exception/DynamoDbException.phpYRߣ$7Aws/DynamoDb/Exception/IncompleteSignatureException.phpYR#Ӷ3Aws/DynamoDb/Exception/InternalFailureException.phpYRTw7Aws/DynamoDb/Exception/InternalServerErrorException.phpYR CAws/DynamoDb/Exception/ItemCollectionSizeLimitExceededException.phpEYRE7 >1Aws/DynamoDb/Exception/LimitExceededException.php:YR:_6>Aws/DynamoDb/Exception/MissingAuthenticationTokenException.phpYRAAws/DynamoDb/Exception/ProvisionedThroughputExceededException.phpYR^zL1Aws/DynamoDb/Exception/ResourceInUseException.phphYRhSY4Aws/DynamoDb/Exception/ResourceNotFoundException.phpEYREƤ6Aws/DynamoDb/Exception/ServiceUnavailableException.phpYRW{.Aws/DynamoDb/Exception/ThrottlingException.phpYRfr<Aws/DynamoDb/Exception/UnprocessedWriteRequestsException.phpYRm1i6Aws/DynamoDb/Exception/UnrecognizedClientException.phpYRe>.Aws/DynamoDb/Exception/ValidationException.phpYR]J&Aws/DynamoDb/Iterator/ItemIterator.phpb YRb D&Aws/DynamoDb/Iterator/ScanIterator.phpqYRq2 Aws/DynamoDb/Model/Attribute.phpYR?8Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.phpYR/61Aws/DynamoDb/Model/BatchRequest/DeleteRequest.php YR y|r.Aws/DynamoDb/Model/BatchRequest/PutRequest.php YR )F:6Aws/DynamoDb/Model/BatchRequest/UnprocessedRequest.php YR 5[85Aws/DynamoDb/Model/BatchRequest/WriteRequestBatch.php%YR%hb=Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.phpcYRc(Զ9Aws/DynamoDb/Model/BatchRequest/WriteRequestInterface.phpYR7 Aws/DynamoDb/Model/Item.phpYR,.Aws/DynamoDb/Resources/dynamodb-2011-12-05.php5YR5+ ۶.Aws/DynamoDb/Resources/dynamodb-2012-08-10.phpYR@Aws/DynamoDb/Session/LockingStrategy/AbstractLockingStrategy.php YR E7f?Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactory.php YR ! 8HAws/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryInterface.phpYRe%AAws/DynamoDb/Session/LockingStrategy/LockingStrategyInterface.phpYRIͶ<Aws/DynamoDb/Session/LockingStrategy/NullLockingStrategy.phpYRBPgCAws/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategy.phpdYRd 'Aws/DynamoDb/Session/SessionHandler.php?YR?+w1-Aws/DynamoDb/Session/SessionHandlerConfig.php* YR* "&0Aws/DynamoDb/Session/SessionHandlerInterface.php8YR81Aws/Ec2/Ec2Client.phpdYRdn5> Aws/Ec2/Enum/ContainerFormat.phpYRJ`ݶ Aws/Ec2/Enum/DiskImageFormat.php#YR#NnAws/Ec2/Enum/DomainType.php YR 'Zl"Aws/Ec2/Enum/ExportEnvironment.php=YR=0Aws/Ec2/Enum/HypervisorType.phpYR&Aws/Ec2/Enum/ImageState.phpYRF\¶&Aws/Ec2/Enum/InstanceAttributeName.phpYR"Aws/Ec2/Enum/InstanceStateName.phpYRAws/Ec2/Enum/InstanceType.phpYR$Aws/Ec2/Enum/PlacementGroupState.phpfYRf}|"Aws/Ec2/Enum/PlacementStrategy.phpYRAWAws/Ec2/Enum/ResourceType.phpYRl}Aws/Ec2/Enum/RuleAction.phpYRRre&Aws/Ec2/Enum/SnapshotAttributeName.phpQYRQ.5Aws/Ec2/Enum/SnapshotState.php5YR5D¶!Aws/Ec2/Enum/SpotInstanceType.php$YR$)]#Aws/Ec2/Enum/VirtualizationType.php YR 7Hg&Aws/Ec2/Enum/VolumeAttachmentState.phppYRpV$Aws/Ec2/Enum/VolumeAttributeName.php9YR9ͶAws/Ec2/Enum/VolumeState.phpYRlAws/Ec2/Enum/VolumeType.php YR F"!Aws/Ec2/Enum/VpcAttributeName.phpHYRHr"Aws/Ec2/Exception/Ec2Exception.phpYR.Aws/Ec2/Iterator/DescribeInstancesIterator.phpcYRcx$Aws/Ec2/Resources/ec2-2013-10-15.phps YRs ,%Aws/ElastiCache/ElastiCacheClient.php}YR} ˔#Aws/ElastiCache/Enum/SourceType.phpYRVAAAws/ElastiCache/Exception/AuthorizationAlreadyExistsException.php1YR1s<Aws/ElastiCache/Exception/AuthorizationNotFoundException.php(YR(*@Aws/ElastiCache/Exception/CacheClusterAlreadyExistsException.php YR K8;Aws/ElastiCache/Exception/CacheClusterNotFoundException.phpYR/GAws/ElastiCache/Exception/CacheParameterGroupAlreadyExistsException.phpYRh7<BAws/ElastiCache/Exception/CacheParameterGroupNotFoundException.php*YR*5u\GAws/ElastiCache/Exception/CacheParameterGroupQuotaExceededException.php6YR6FFAws/ElastiCache/Exception/CacheSecurityGroupAlreadyExistsException.phpYRCʶAAws/ElastiCache/Exception/CacheSecurityGroupNotFoundException.php'YR'\9FAws/ElastiCache/Exception/CacheSecurityGroupQuotaExceededException.php5YR57DAws/ElastiCache/Exception/CacheSubnetGroupAlreadyExistsException.php)YR)[#kѶ<Aws/ElastiCache/Exception/CacheSubnetGroupInUseException.phpYRXC?Aws/ElastiCache/Exception/CacheSubnetGroupNotFoundException.php!YR!YDAws/ElastiCache/Exception/CacheSubnetGroupQuotaExceededException.php1YR1v8?Aws/ElastiCache/Exception/CacheSubnetQuotaExceededException.php8YR8zֶFAws/ElastiCache/Exception/ClusterQuotaForCustomerExceededException.php;YR;㉬2Aws/ElastiCache/Exception/ElastiCacheException.phpYRBWGAws/ElastiCache/Exception/InsufficientCacheClusterCapacityException.php$YR$a?Aws/ElastiCache/Exception/InvalidCacheClusterStateException.phpYR FAws/ElastiCache/Exception/InvalidCacheParameterGroupStateException.php-YR-9EAws/ElastiCache/Exception/InvalidCacheSecurityGroupStateException.phpYR0fBAws/ElastiCache/Exception/InvalidParameterCombinationException.phpYRG\<Aws/ElastiCache/Exception/InvalidParameterValueException.phpYRb[ CAws/ElastiCache/Exception/InvalidReplicationGroupStateException.php YR <4Aws/ElastiCache/Exception/InvalidSubnetException.phpYR;g=Aws/ElastiCache/Exception/InvalidVPCNetworkStateException.phpYR>ŸBAws/ElastiCache/Exception/NodeQuotaForClusterExceededException.phpAYRA'sCAws/ElastiCache/Exception/NodeQuotaForCustomerExceededException.php5YR5aDAws/ElastiCache/Exception/ReplicationGroupAlreadyExistsException.phpYR[jSx?Aws/ElastiCache/Exception/ReplicationGroupNotFoundException.phpYR㱶EAws/ElastiCache/Exception/ReservedCacheNodeAlreadyExistsException.phpYRK-Ԯ@Aws/ElastiCache/Exception/ReservedCacheNodeNotFoundException.phpYR,EAws/ElastiCache/Exception/ReservedCacheNodeQuotaExceededException.php$YR$2IAws/ElastiCache/Exception/ReservedCacheNodesOfferingNotFoundException.phpYRŶ2Aws/ElastiCache/Exception/SubnetInUseException.phpYRVH4Aws/ElastiCache/Resources/elasticache-2013-06-15.php!!YR!!h/Aws/ElasticBeanstalk/ElasticBeanstalkClient.phpCYRC=Ú;Aws/ElasticBeanstalk/Enum/ConfigurationDeploymentStatus.phpbYRbZ4:Aws/ElasticBeanstalk/Enum/ConfigurationOptionValueType.phpCYRC;/Aws/ElasticBeanstalk/Enum/EnvironmentHealth.phpUYRUUD1Aws/ElasticBeanstalk/Enum/EnvironmentInfoType.php YR $3/Aws/ElasticBeanstalk/Enum/EnvironmentStatus.phpYRQ+Aws/ElasticBeanstalk/Enum/EventSeverity.phpYR;m0Aws/ElasticBeanstalk/Enum/ValidationSeverity.php)YR)<Aws/ElasticBeanstalk/Exception/ElasticBeanstalkException.phpYRBAws/ElasticBeanstalk/Exception/InsufficientPrivilegesException.phpTYRTw_'?Aws/ElasticBeanstalk/Exception/OperationInProgressException.phpSYRSORHAws/ElasticBeanstalk/Exception/S3LocationNotInServiceRegionException.php1YR1O'dʶBAws/ElasticBeanstalk/Exception/S3SubscriptionRequiredException.phpYRCҶ@Aws/ElasticBeanstalk/Exception/SourceBundleDeletionException.php\YR\Ky?Aws/ElasticBeanstalk/Exception/TooManyApplicationsException.php-YR-ٲöFAws/ElasticBeanstalk/Exception/TooManyApplicationVersionsException.php<YR<Lz :Aws/ElasticBeanstalk/Exception/TooManyBucketsException.php,YR,ζIAws/ElasticBeanstalk/Exception/TooManyConfigurationTemplatesException.phpBYRB22?Aws/ElasticBeanstalk/Exception/TooManyEnvironmentsException.php%YR%l>Aws/ElasticBeanstalk/Resources/elasticbeanstalk-2010-12-01.phpOyYROyĶ7Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.phpiYRio,CAws/ElasticLoadBalancing/Exception/AccessPointNotFoundException.phpYR@CAws/ElasticLoadBalancing/Exception/CertificateNotFoundException.phpHYRH0HAws/ElasticLoadBalancing/Exception/DuplicateAccessPointNameException.php+YR+kBAAws/ElasticLoadBalancing/Exception/DuplicateListenerException.phpeYRe5LlCAws/ElasticLoadBalancing/Exception/DuplicatePolicyNameException.php+YR+> DAws/ElasticLoadBalancing/Exception/ElasticLoadBalancingException.php&YR&+M KAws/ElasticLoadBalancing/Exception/InvalidConfigurationRequestException.php YR !ߨݶ?Aws/ElasticLoadBalancing/Exception/InvalidEndPointException.phpYRY=Aws/ElasticLoadBalancing/Exception/InvalidSchemeException.php"YR" zֶDAws/ElasticLoadBalancing/Exception/InvalidSecurityGroupException.php YR &==Aws/ElasticLoadBalancing/Exception/InvalidSubnetException.phpYR>@Aws/ElasticLoadBalancing/Exception/ListenerNotFoundException.phpYRN˶MAws/ElasticLoadBalancing/Exception/LoadBalancerAttributeNotFoundException.phpYR.>>Aws/ElasticLoadBalancing/Exception/PolicyNotFoundException.phpYR韶BAws/ElasticLoadBalancing/Exception/PolicyTypeNotFoundException.php YR LG>Aws/ElasticLoadBalancing/Exception/SubnetNotFoundException.phpYRnCAws/ElasticLoadBalancing/Exception/TooManyAccessPointsException.phpYRQ-}?Aws/ElasticLoadBalancing/Exception/TooManyPoliciesException.php YR ʶFAws/ElasticLoadBalancing/Resources/elasticloadbalancing-2012-06-01.phpK1YRK1h1Aws/ElasticTranscoder/ElasticTranscoderClient.phpYR!9Aws/ElasticTranscoder/Exception/AccessDeniedException.phpYR=}߶>Aws/ElasticTranscoder/Exception/ElasticTranscoderException.php YR Ĺق@Aws/ElasticTranscoder/Exception/IncompatibleVersionException.phpYRľr<Aws/ElasticTranscoder/Exception/InternalServiceException.php(YR(k:Aws/ElasticTranscoder/Exception/LimitExceededException.php9YR9):Aws/ElasticTranscoder/Exception/ResourceInUseException.phpNYRNFN=Aws/ElasticTranscoder/Exception/ResourceNotFoundException.phpoYRoA?t[7Aws/ElasticTranscoder/Exception/ValidationException.phpYRV,@Aws/ElasticTranscoder/Resources/elastictranscoder-2012-09-25.phpYR)ֶAws/Emr/EmrClient.phpKYRKg  Aws/Emr/Enum/ActionOnFailure.phpYR%Aws/Emr/Enum/ClusterState.phpYRQ -Aws/Emr/Enum/ClusterStateChangeReasonCode.phpAYRA߶#Aws/Emr/Enum/InstanceGroupState.phpLYRL^3Aws/Emr/Enum/InstanceGroupStateChangeReasonCode.phpYRUs"Aws/Emr/Enum/InstanceGroupType.php/YR/iն!Aws/Emr/Enum/InstanceRoleType.php-YR-Aws/Emr/Enum/InstanceState.phpYR-Ķ.Aws/Emr/Enum/InstanceStateChangeReasonCode.phpYRNɶ&Aws/Emr/Enum/JobFlowExecutionState.phpYRwTĶAws/Emr/Enum/MarketType.phpYRo#Aws/Emr/Enum/StepExecutionState.phpYRU05Aws/Emr/Enum/StepState.phpYRF㦶*Aws/Emr/Enum/StepStateChangeReasonCode.php YR l-"Aws/Emr/Exception/EmrException.phpYR23x2Aws/Emr/Exception/InternalServerErrorException.phpYR+-Aws/Emr/Exception/InternalServerException.phpYRi4aK-Aws/Emr/Exception/InvalidRequestException.phpYROa$Aws/Emr/Resources/emr-2009-03-31.phpbYRb3˺Aws/Glacier/Enum/Action.phpzYRz.㒶Aws/Glacier/Enum/ActionCode.php>YR> jζAws/Glacier/Enum/StatusCode.php<YR<ӰV*Aws/Glacier/Exception/GlacierException.php YR lc8Aws/Glacier/Exception/InvalidParameterValueException.phpYR0wa0Aws/Glacier/Exception/LimitExceededException.phpYR-~8Aws/Glacier/Exception/MissingParameterValueException.phpYR1Aws/Glacier/Exception/RequestTimeoutException.phpYRx3Aws/Glacier/Exception/ResourceNotFoundException.phpYR5Aws/Glacier/Exception/ServiceUnavailableException.phpYRedAws/Glacier/GlacierClient.php YR 3Aws/Iam/Exception/MalformedCertificateException.php0YR0C6Aws/Iam/Exception/MalformedPolicyDocumentException.php,YR,4܂T+Aws/Iam/Exception/NoSuchEntityException.php#YR#C86Aws/Iam/Exception/PasswordPolicyViolationException.php5YR5젥jAws/Iam/IamClient.phpI,YRI,ɾ7$Aws/Iam/Resources/iam-2010-05-08.phpYR6/!Aws/ImportExport/Enum/JobType.phpYRFশ8Aws/ImportExport/Exception/BucketPermissionException.php YR q@5Aws/ImportExport/Exception/CanceledJobIdException.phpYR4Aws/ImportExport/Exception/ExpiredJobIdException.phpYRn4Aws/ImportExport/Exception/ImportExportException.phpYR:Aws/ImportExport/Exception/InvalidAccessKeyIdException.phpuYRu T6Aws/ImportExport/Exception/InvalidAddressException.phpYR{6Aws/ImportExport/Exception/InvalidCustomsException.php YR $6f9Aws/ImportExport/Exception/InvalidFileSystemException.phpYR("4Aws/ImportExport/Exception/InvalidJobIdException.php YR [ߕm<Aws/ImportExport/Exception/InvalidManifestFieldException.php YR !⳶8Aws/ImportExport/Exception/InvalidParameterException.phpYRu9Aws/ImportExport/Exception/MalformedManifestException.phpYR;q6Aws/ImportExport/Exception/MissingCustomsException.phpYR8e<Aws/ImportExport/Exception/MissingManifestFieldException.php%YR%霶8Aws/ImportExport/Exception/MissingParameterException.phpYR3eض7Aws/ImportExport/Exception/MultipleRegionsException.phpKYRKK޶4Aws/ImportExport/Exception/NoSuchBucketException.phpYRvd;Aws/ImportExport/Exception/UnableToCancelJobIdException.phpYR{e'Aws/ImportExport/ImportExportClient.php YR 17.Aws/ImportExport/Iterator/ListJobsIterator.phpYR<ᐶ(Aws/ImportExport/JobManifestListener.phpYR6Aws/ImportExport/Resources/importexport-2010-06-01.phpYYRY&Aws/Kinesis/Enum/ShardIteratorType.phpYRC!Aws/Kinesis/Enum/StreamStatus.phpZYRZm6$2Aws/Kinesis/Exception/ExpiredIteratorException.phpYRO2Aws/Kinesis/Exception/InvalidArgumentException.phpYR+*Aws/Kinesis/Exception/KinesisException.php YR s5ʶ0Aws/Kinesis/Exception/LimitExceededException.phpYR7@Aws/Kinesis/Exception/ProvisionedThroughputExceededException.phpYR!0Aws/Kinesis/Exception/ResourceInUseException.phpYR5'3Aws/Kinesis/Exception/ResourceNotFoundException.phpYRWAws/Kinesis/KinesisClient.phpA YRA / ж,Aws/Kinesis/Resources/kinesis-2013-12-02.php\YR\6Aws/LICENSE.md#YR#l Aws/NOTICE.mdYRzAws/OpsWorks/Enum/AppType.phpqYRqW"Aws/OpsWorks/Enum/Architecture.phpYRs%Aws/OpsWorks/Enum/AutoScalingType.phpYRRjö+Aws/OpsWorks/Enum/DeploymentCommandName.php}YR}܆Aws/OpsWorks/Enum/LayerType.phpYRZ?%Aws/OpsWorks/Enum/PermissionLevel.phpMYRMt2$Aws/OpsWorks/Enum/RootDeviceType.php#YR#IVm Aws/OpsWorks/Enum/SourceType.php9YR9߭ty,Aws/OpsWorks/Exception/OpsWorksException.phpYR%ܶ4Aws/OpsWorks/Exception/ResourceNotFoundException.phpYR?\.Aws/OpsWorks/Exception/ValidationException.phpYR qtAws/OpsWorks/OpsWorksClient.php%YR%Ҁ.Aws/OpsWorks/Resources/opsworks-2013-02-18.phpYRħ%Aws/Rds/Enum/ApplyMethod.php$YR$7RAws/Rds/Enum/SourceType.phpYRbA9Aws/Rds/Exception/AuthorizationAlreadyExistsException.php!YR!FͶ4Aws/Rds/Exception/AuthorizationNotFoundException.phpYRm59Aws/Rds/Exception/AuthorizationQuotaExceededException.phpYRY36Aws/Rds/Exception/DBInstanceAlreadyExistsException.phpYR>A1Aws/Rds/Exception/DBInstanceNotFoundException.phpYRH<Aws/Rds/Exception/DBParameterGroupAlreadyExistsException.phpYRt;7Aws/Rds/Exception/DBParameterGroupNotFoundException.phpYR|J!<Aws/Rds/Exception/DBParameterGroupQuotaExceededException.phpYR֧;Aws/Rds/Exception/DBSecurityGroupAlreadyExistsException.phpYRA6Aws/Rds/Exception/DBSecurityGroupNotFoundException.phpYR P:Aws/Rds/Exception/DBSecurityGroupNotSupportedException.phpYRQ;Aws/Rds/Exception/DBSecurityGroupQuotaExceededException.phpYR6Aws/Rds/Exception/DBSnapshotAlreadyExistsException.phpYRL[1Aws/Rds/Exception/DBSnapshotNotFoundException.phpYRd9Aws/Rds/Exception/DBSubnetGroupAlreadyExistsException.phpYRI0AAws/Rds/Exception/DBSubnetGroupDoesNotCoverEnoughAZsException.php8YR8K6Aws/Rds/Exception/DBSubnetGroupNotAllowedException.phpBYRB5 ۩4Aws/Rds/Exception/DBSubnetGroupNotFoundException.phpYR9Aws/Rds/Exception/DBSubnetGroupQuotaExceededException.php YR vB4Aws/Rds/Exception/DBSubnetQuotaExceededException.phpYR299Aws/Rds/Exception/DBUpgradeDependencyFailureException.php YR 4D&Ҷ=Aws/Rds/Exception/EventSubscriptionQuotaExceededException.phpYR64Aws/Rds/Exception/InstanceQuotaExceededException.phpYR=Aws/Rds/Exception/InsufficientDBInstanceCapacityException.phpYRhW5Aws/Rds/Exception/InvalidDBInstanceStateException.phpYR;Aws/Rds/Exception/InvalidDBParameterGroupStateException.phpYRmSM:Aws/Rds/Exception/InvalidDBSecurityGroupStateException.phpYR;5Aws/Rds/Exception/InvalidDBSnapshotStateException.phpYR|[3Aws/Rds/Exception/InvalidDBSubnetGroupException.php?YR?'".8Aws/Rds/Exception/InvalidDBSubnetGroupStateException.phpYRh3Aws/Rds/Exception/InvalidDBSubnetStateException.phpYRK<Aws/Rds/Exception/InvalidEventSubscriptionStateException.phpYR(=6Aws/Rds/Exception/InvalidOptionGroupStateException.phpYRɎ-Aws/Rds/Exception/InvalidRestoreException.phpYRS,Aws/Rds/Exception/InvalidSubnetException.phpYR̬!5Aws/Rds/Exception/InvalidVPCNetworkStateException.phpYR ϣ7Aws/Rds/Exception/OptionGroupAlreadyExistsException.phpYRH@r2Aws/Rds/Exception/OptionGroupNotFoundException.phpYRo 7Aws/Rds/Exception/OptionGroupQuotaExceededException.phpYR3K;Aws/Rds/Exception/PointInTimeRestoreNotEnabledException.phpYRM>Aws/Rds/Exception/ProvisionedIopsNotAvailableInAZException.phpYR#"Aws/Rds/Exception/RdsException.phpYRܶ>Aws/Rds/Exception/ReservedDBInstanceAlreadyExistsException.phpYRL9Aws/Rds/Exception/ReservedDBInstanceNotFoundException.phpYR>Aws/Rds/Exception/ReservedDBInstanceQuotaExceededException.phpYR_D@BAws/Rds/Exception/ReservedDBInstancesOfferingNotFoundException.phpYR4Aws/Rds/Exception/SnapshotQuotaExceededException.phpYR..Aws/Rds/Exception/SNSInvalidTopicException.phpYRU1Aws/Rds/Exception/SNSNoAuthorizationException.phpYRR452Aws/Rds/Exception/SNSTopicArnNotFoundException.phpYRK1-Aws/Rds/Exception/SourceNotFoundException.phpYR3Aws/Rds/Exception/StorageQuotaExceededException.phpYR<Ƕ1Aws/Rds/Exception/SubnetAlreadyInUseException.phpYRmcL7Aws/Rds/Exception/SubscriptionAlreadyExistException.phpYRik¶;Aws/Rds/Exception/SubscriptionCategoryNotFoundException.phpYRa 3Aws/Rds/Exception/SubscriptionNotFoundException.phpYR5Aws/Rds/RdsClient.php)YR)}{{$Aws/Rds/Resources/rds-2013-09-09.phpzYRz\x Aws/Redshift/Enum/SourceType.phpYR#/:Aws/Redshift/Exception/AccessToSnapshotDeniedException.phpYRAŶ>Aws/Redshift/Exception/AuthorizationAlreadyExistsException.php4YR4Zp9Aws/Redshift/Exception/AuthorizationNotFoundException.php.YR.a6 >Aws/Redshift/Exception/AuthorizationQuotaExceededException.phpYRc2Aws/Redshift/Exception/BucketNotFoundException.phpYRK_8Aws/Redshift/Exception/ClusterAlreadyExistsException.phpYR3C|3Aws/Redshift/Exception/ClusterNotFoundException.phpYR>YoFAws/Redshift/Exception/ClusterParameterGroupAlreadyExistsException.php YR _AAws/Redshift/Exception/ClusterParameterGroupNotFoundException.phpYR.桶FAws/Redshift/Exception/ClusterParameterGroupQuotaExceededException.phpYRն8Aws/Redshift/Exception/ClusterQuotaExceededException.phpYRTEAws/Redshift/Exception/ClusterSecurityGroupAlreadyExistsException.phpYR +@Aws/Redshift/Exception/ClusterSecurityGroupNotFoundException.phpYRR_EAws/Redshift/Exception/ClusterSecurityGroupQuotaExceededException.phpYREɶ@Aws/Redshift/Exception/ClusterSnapshotAlreadyExistsException.phpYRBi;Aws/Redshift/Exception/ClusterSnapshotNotFoundException.php YR "H@Aws/Redshift/Exception/ClusterSnapshotQuotaExceededException.phpYR|õCAws/Redshift/Exception/ClusterSubnetGroupAlreadyExistsException.phpYR͒>Aws/Redshift/Exception/ClusterSubnetGroupNotFoundException.phpYR^m?CAws/Redshift/Exception/ClusterSubnetGroupQuotaExceededException.phpYR[hm>Aws/Redshift/Exception/ClusterSubnetQuotaExceededException.phpYRF18Aws/Redshift/Exception/CopyToRegionDisabledException.php YR ;mbBAws/Redshift/Exception/EventSubscriptionQuotaExceededException.phpYRjEAws/Redshift/Exception/HsmClientCertificateAlreadyExistsException.php/YR/ҧʶ@Aws/Redshift/Exception/HsmClientCertificateNotFoundException.phpYRdEAws/Redshift/Exception/HsmClientCertificateQuotaExceededException.phpzYRzAAws/Redshift/Exception/HsmConfigurationAlreadyExistsException.php&YR&i<Aws/Redshift/Exception/HsmConfigurationNotFoundException.phpYRVlAAws/Redshift/Exception/HsmConfigurationQuotaExceededException.phpqYRq6~@Aws/Redshift/Exception/IncompatibleOrderableOptionsException.phpYR⽶?Aws/Redshift/Exception/InsufficientClusterCapacityException.phpYRpwCAws/Redshift/Exception/InsufficientS3BucketPolicyFaultException.php<YR<{iEAws/Redshift/Exception/InvalidClusterParameterGroupStateException.php{YR{X{DAws/Redshift/Exception/InvalidClusterSecurityGroupStateException.phpYR#4?Aws/Redshift/Exception/InvalidClusterSnapshotStateException.php5YR5h 7Aws/Redshift/Exception/InvalidClusterStateException.phpYR}ȰBAws/Redshift/Exception/InvalidClusterSubnetGroupStateException.php YR Hs==Aws/Redshift/Exception/InvalidClusterSubnetStateException.phpYR4Aws/Redshift/Exception/InvalidElasticIpException.phpYRRDAws/Redshift/Exception/InvalidHsmClientCertificateStateException.phpNYRN@Aws/Redshift/Exception/InvalidHsmConfigurationStateException.phpEYRE422Aws/Redshift/Exception/InvalidRestoreException.phpYRڸ<Aws/Redshift/Exception/InvalidS3BucketNameFaultException.phppYRpCJ;Aws/Redshift/Exception/InvalidS3KeyPrefixFaultException.php&YR& b1Aws/Redshift/Exception/InvalidSubnetException.php YR U-ֶ:Aws/Redshift/Exception/InvalidVPCNetworkStateException.phpYRůHAws/Redshift/Exception/NumberOfNodesPerClusterLimitExceededException.phpYR@>Aws/Redshift/Exception/NumberOfNodesQuotaExceededException.phpYR׋c,Aws/Redshift/Exception/RedshiftException.phpYRÈ=Aws/Redshift/Exception/ReservedNodeAlreadyExistsException.phpYRlڶ8Aws/Redshift/Exception/ReservedNodeNotFoundException.phpYR5O@Aws/Redshift/Exception/ReservedNodeOfferingNotFoundException.phpYRdu=Aws/Redshift/Exception/ReservedNodeQuotaExceededException.phpnYRn =N2Aws/Redshift/Exception/ResizeNotFoundException.phpYR?Aws/Redshift/Exception/SnapshotCopyAlreadyDisabledException.phpYRE >Aws/Redshift/Exception/SnapshotCopyAlreadyEnabledException.phpYR$*/8Aws/Redshift/Exception/SnapshotCopyDisabledException.php YR ::-˶3Aws/Redshift/Exception/SNSInvalidTopicException.phpYRV6Aws/Redshift/Exception/SNSNoAuthorizationException.phpYR#7Aws/Redshift/Exception/SNSTopicArnNotFoundException.phpYRٶ2Aws/Redshift/Exception/SourceNotFoundException.phpYRew6Aws/Redshift/Exception/SubnetAlreadyInUseException.phpYR>o<Aws/Redshift/Exception/SubscriptionAlreadyExistException.phpYR+ٶ@Aws/Redshift/Exception/SubscriptionCategoryNotFoundException.phpYRd0G?Aws/Redshift/Exception/SubscriptionEventIdNotFoundException.php YR )`18Aws/Redshift/Exception/SubscriptionNotFoundException.phpYRJa0@Aws/Redshift/Exception/SubscriptionSeverityNotFoundException.phpYR4Ge9Aws/Redshift/Exception/UnauthorizedOperationException.phpYR=Aws/Redshift/Exception/UnknownSnapshotCopyRegionException.phpYR(5Aws/Redshift/Exception/UnsupportedOptionException.phpYRƓ`=Aws/Redshift/RedshiftClient.php*YR*}8.Aws/Redshift/Resources/redshift-2012-12-01.php_YR_aҶAws/Route53/Enum/Action.phpYRW%$Aws/Route53/Enum/HealthCheckType.phpYRF|Aws/Route53/Enum/RecordType.phpYR.Aws/Route53/Enum/ResourceRecordSetFailover.php6YR6#ΖAws/Route53/Enum/Status.php YR l-p<Aws/Route53/Exception/DelegationSetNotAvailableException.phpYRu;Aws/Route53/Exception/HealthCheckAlreadyExistsException.phphYRh6%3Aws/Route53/Exception/HealthCheckInUseException.phpWYRWAws/Route53/Route53Client.php*YR*]xAws/S3/AcpListener.php YR Aws/S3/BucketStyleListener.php YR S>Aws/S3/Command/S3Command.phpYR;Aws/S3/Enum/CannedAcl.phpYRHAws/S3/Enum/EncodingType.phpYRcNAws/S3/Enum/Event.phpYR1XAws/S3/Enum/GranteeType.php;YR;?ѷAws/S3/Enum/Group.phpYRG y!Aws/S3/Enum/MetadataDirective.phpYR[.ҶAws/S3/Enum/MFADelete.phpYR3Aws/S3/Enum/Payer.phpYRAws/S3/Enum/Permission.phprYRrRoAws/S3/Enum/Protocol.phpYR{E$Aws/S3/Enum/ServerSideEncryption.phpYR[oAws/S3/Enum/Status.php YR :>߶Aws/S3/Enum/Storage.phpAYRAZAws/S3/Enum/StorageClass.php+YR+P*Aws/S3/Exception/AccessDeniedException.phpYRKn,Aws/S3/Exception/AccountProblemException.php'YR'ɒ:Aws/S3/Exception/AmbiguousGrantByEmailAddressException.phpYR#v'Aws/S3/Exception/BadDigestException.phpYRuv1Aws/S3/Exception/BucketAlreadyExistsException.phpGYRGFF5Aws/S3/Exception/BucketAlreadyOwnedByYouException.php YR Y8jڶ,Aws/S3/Exception/BucketNotEmptyException.phpYR55Aws/S3/Exception/CredentialsNotSupportedException.phpYRR1<Aws/S3/Exception/CrossLocationLoggingProhibitedException.php<YR<3Aws/S3/Exception/DeleteMultipleObjectsException.phpeYReԬ,Aws/S3/Exception/EntityTooLargeException.phpYR(ꑶ,Aws/S3/Exception/EntityTooSmallException.phpYR^*Aws/S3/Exception/ExpiredTokenException.phpYRߘ<Aws/S3/Exception/IllegalVersioningConfigurationException.phpYR,Aws/S3/Exception/IncompleteBodyException.phpYR0AAws/S3/Exception/IncorrectNumberOfFilesInPostRequestException.phpYR 0Aws/S3/Exception/InlineDataTooLargeException.phpYR u+Aws/S3/Exception/InternalErrorException.phpYRwٜ0Aws/S3/Exception/InvalidAccessKeyIdException.phpYR̤5Aws/S3/Exception/InvalidAddressingHeaderException.phpYR`O-Aws/S3/Exception/InvalidArgumentException.phpYR&4y/Aws/S3/Exception/InvalidBucketNameException.phpYRQږ0Aws/S3/Exception/InvalidBucketStateException.phpYRQ<+Aws/S3/Exception/InvalidDigestException.phpYRhj7Aws/S3/Exception/InvalidLocationConstraintException.php9YR9"Ly~)Aws/S3/Exception/InvalidPartException.phpRYRRچ.Aws/S3/Exception/InvalidPartOrderException.phpYR*Aws/S3/Exception/InvalidPayerException.phpYR̓<3Aws/S3/Exception/InvalidPolicyDocumentException.php YR g "*Aws/S3/Exception/InvalidRangeException.phpYR/䡶,Aws/S3/Exception/InvalidRequestException.phpYR-Aws/S3/Exception/InvalidSecurityException.phpYR} 0Aws/S3/Exception/InvalidSOAPRequestException.phpYRB1Aws/S3/Exception/InvalidStorageClassException.phpYRE-Aws/S3/Exception/InvalidTagErrorException.phpMYRM;Aws/S3/Exception/InvalidTargetBucketForLoggingException.phpCYRC*Aws/S3/Exception/InvalidTokenException.phpYR/Ҥ(Aws/S3/Exception/InvalidURIException.phpYRx(Aws/S3/Exception/KeyTooLongException.phpYRL/Aws/S3/Exception/MalformedACLErrorException.php YR y2Aws/S3/Exception/MalformedPOSTRequestException.phpYR44*Aws/S3/Exception/MalformedXMLException.phpYRhWJ6Aws/S3/Exception/MaxMessageLengthExceededException.phpYRf!׶?Aws/S3/Exception/MaxPostPreDataLengthExceededErrorException.phpYR .Aws/S3/Exception/MetadataTooLargeException.phpYR".Aws/S3/Exception/MethodNotAllowedException.phpYR#aӶ/Aws/S3/Exception/MissingAttachmentException.phpYRh a2Aws/S3/Exception/MissingContentLengthException.phpYR R5Aws/S3/Exception/MissingRequestBodyErrorException.php*YR*W4Aws/S3/Exception/MissingSecurityElementException.phpYRnmG3Aws/S3/Exception/MissingSecurityHeaderException.phpYR޶3Aws/S3/Exception/NoLoggingStatusForKeyException.phpYRR*Aws/S3/Exception/NoSuchBucketException.phpYR*O.0Aws/S3/Exception/NoSuchBucketPolicyException.phpYR^_ն5Aws/S3/Exception/NoSuchCORSConfigurationException.phpYR[:7'Aws/S3/Exception/NoSuchKeyException.phpYR:Aws/S3/Exception/NoSuchLifecycleConfigurationException.phpYR@/Aws/S3/Exception/NoSuchTagSetErrorException.phpYRk`*Aws/S3/Exception/NoSuchUploadException.phpYRyY+Aws/S3/Exception/NoSuchVersionException.phpYRJŗ8Aws/S3/Exception/NoSuchWebsiteConfigurationException.phpYR*,Aws/S3/Exception/NotImplementedException.phpYRm)Aws/S3/Exception/NotSignedUpException.phpQYRQF1Aws/S3/Exception/NotSuchBucketPolicyException.phpYRk޷<Aws/S3/Exception/ObjectAlreadyInActiveTierErrorException.phpYRTb8Aws/S3/Exception/ObjectNotInActiveTierErrorException.php!YR!'.Aws/S3/Exception/OperationAbortedException.phpYRl--Aws/S3/Exception/Parser/S3ExceptionParser.phpYR/Aws/S3/Exception/PermanentRedirectException.php:YR:u}0Aws/S3/Exception/PreconditionFailedException.phpYRsP&Aws/S3/Exception/RedirectException.phpYRc:Aws/S3/Exception/RequestIsNotMultiPartContentException.phpYR1a,Aws/S3/Exception/RequestTimeoutException.php YR 쐶2Aws/S3/Exception/RequestTimeTooSkewedException.phpYR`s9Aws/S3/Exception/RequestTorrentOfBucketErrorException.phpYRƬ Aws/S3/Exception/S3Exception.phpYR0Aws/S3/Exception/ServiceUnavailableException.phpYRف63Aws/S3/Exception/SignatureDoesNotMatchException.phpYRns&Aws/S3/Exception/SlowDownException.phpYRj/Aws/S3/Exception/TemporaryRedirectException.phpYRũ2Aws/S3/Exception/TokenRefreshRequiredException.phpYRDf,Aws/S3/Exception/TooManyBucketsException.phpYR /Aws/S3/Exception/UnexpectedContentException.phpYR֠mݶ=Aws/S3/Exception/UnresolvableGrantByEmailAddressException.phpYR4Aws/S3/Exception/UserKeyMustBeSpecifiedException.php&YR&8'Aws/S3/Iterator/ListBucketsIterator.php\YR\M>0Aws/S3/Iterator/ListMultipartUploadsIterator.phpYR@@'Aws/S3/Iterator/ListObjectsIterator.php YR  .Aws/S3/Iterator/ListObjectVersionsIterator.phpYRY@#Aws/S3/Iterator/OpendirIterator.php6YR6@ǶAws/S3/Model/Acp.php'YR'6CAws/S3/Model/AcpBuilder.phpF YRF ꀡöAws/S3/Model/ClearBucket.phpYRa'#Aws/S3/Model/DeleteObjectsBatch.php YR &Aws/S3/Model/DeleteObjectsTransfer.phpuYRuQqAws/S3/Model/Grant.php/ YR/ 밶Aws/S3/Model/Grantee.php~YR~cm1Aws/S3/Model/MultipartUpload/AbstractTransfer.php YR m1Aws/S3/Model/MultipartUpload/ParallelTransfer.phpYR4f/Aws/S3/Model/MultipartUpload/SerialTransfer.phpu YRu Y.Aws/S3/Model/MultipartUpload/TransferState.phpYR㋄.Aws/S3/Model/MultipartUpload/UploadBuilder.phpt!YRt!❩)Aws/S3/Model/MultipartUpload/UploadId.phpYR+Aws/S3/Model/MultipartUpload/UploadPart.phpYRlAws/S3/Model/PostObject.phpVYRV@l"Aws/S3/Resources/s3-2006-03-01.php:xYR:xz榶Aws/S3/ResumableDownload.phpkYRkSAws/S3/S3Client.phpqwYRqw FLAws/S3/S3Md5Listener.phpL YRL ζAws/S3/S3Signature.php;#YR;#ŶAws/S3/S3SignatureInterface.phpYRyնAws/S3/S3SignatureV4.phpYRDy"Aws/S3/SocketTimeoutChecker.phpi YRi dAws/S3/StreamWrapper.phpaYRa/tAws/S3/Sync/AbstractSync.phpYR{_#Aws/S3/Sync/AbstractSyncBuilder.php/YR/m$Aws/S3/Sync/ChangedFilesIterator.php YR 9Aws/S3/Sync/DownloadSync.php: YR: 6#Aws/S3/Sync/DownloadSyncBuilder.phpIYRI&m*Aws/S3/Sync/FilenameConverterInterface.phpYRsxQAws/S3/Sync/KeyConverter.php YR ]Aws/S3/Sync/UploadSync.php YR kֶ!Aws/S3/Sync/UploadSyncBuilder.phpYR e+ضAws/Ses/Enum/IdentityType.phpYR$L!Aws/Ses/Enum/MailboxSimulator.phpFYRFu!Aws/Ses/Enum/NotificationType.phpYR!#Aws/Ses/Enum/VerificationStatus.phpYR&PUh.Aws/Ses/Exception/MessageRejectedException.php=YR=%삛"Aws/Ses/Exception/SesException.phpYR]SP$Aws/Ses/Resources/ses-2010-12-01.phpYRZ %rAws/Ses/SesClient.phpYR@J9Aws/SimpleDb/Exception/AttributeDoesNotExistException.phpYR5Aws/SimpleDb/Exception/DuplicateItemNameException.phpYRx4Aws/SimpleDb/Exception/InvalidNextTokenException.phpYR6;Aws/SimpleDb/Exception/InvalidNumberPredicatesException.phpYR±;Aws/SimpleDb/Exception/InvalidNumberValueTestsException.phpYRI|9Aws/SimpleDb/Exception/InvalidParameterValueException.phpYRKk8z:Aws/SimpleDb/Exception/InvalidQueryExpressionException.phpYRU(DǶ4Aws/SimpleDb/Exception/MissingParameterException.phpYRc0Aws/SimpleDb/Exception/NoSuchDomainException.phpYRO/WBAws/SimpleDb/Exception/NumberDomainAttributesExceededException.phpYRs=Aws/SimpleDb/Exception/NumberDomainBytesExceededException.phpYR"9Aws/SimpleDb/Exception/NumberDomainsExceededException.phpYRy;E@Aws/SimpleDb/Exception/NumberItemAttributesExceededException.phpYR ƀEAws/SimpleDb/Exception/NumberSubmittedAttributesExceededException.phpYRL @Aws/SimpleDb/Exception/NumberSubmittedItemsExceededException.phpYRb2Aws/SimpleDb/Exception/RequestTimeoutException.phpYR-,Aws/SimpleDb/Exception/SimpleDbException.phpYR*s>Aws/SimpleDb/Exception/TooManyRequestedAttributesException.phpYR^.Aws/SimpleDb/Resources/simpledb-2009-04-15.phpKYRKMzAws/SimpleDb/SimpleDbClient.php YR 1Aws/Sns/Exception/AuthorizationErrorException.phpYRd_I/Aws/Sns/Exception/EndpointDisabledException.phpYRۦX,Aws/Sns/Exception/InternalErrorException.phpYR)/Aws/Sns/Exception/InvalidParameterException.phpYR 'Aws/Sns/Exception/NotFoundException.phpYRns̶:Aws/Sns/Exception/PlatformApplicationDisabledException.phpYR"Aws/Sns/Exception/SnsException.phpYR<8Aws/Sns/Exception/SubscriptionLimitExceededException.phpYR)iW1Aws/Sns/Exception/TopicLimitExceededException.phpYRz2QAws/Sns/MessageValidator/Exception/CannotGetPublicKeyFromCertificateException.phptYRtIfhkQAws/Sns/MessageValidator/Exception/CertificateFromUnrecognizedSourceException.phpeYRe6¶GAws/Sns/MessageValidator/Exception/InvalidMessageSignatureException.phpYYRY)[¶CAws/Sns/MessageValidator/Exception/SnsMessageValidatorException.php,YR,5,$Aws/Sns/MessageValidator/Message.phpYRȮh,-Aws/Sns/MessageValidator/MessageValidator.phpYR{B$Aws/Sns/Resources/sns-2010-03-31.php YR Aws/Sns/SnsClient.php"YR" 2!Aws/Sqs/Enum/MessageAttribute.phpYRGAAws/Sqs/Enum/QueueAttribute.phpYRMZ"Aws/Sqs/Exception/SqsException.phpYRE Aws/Sqs/Md5ValidatorListener.phpYRm懶Aws/Sqs/QueueUrlListener.phpFYRF3$Aws/Sqs/Resources/sqs-2012-11-05.php|YR|,<Aws/Sqs/SqsClient.phpYR f)Aws/StorageGateway/Enum/BandwidthType.php8YR8Kb.Aws/StorageGateway/Enum/DiskAllocationType.phpYRo%Aws/StorageGateway/Enum/ErrorCode.phpCYRCl(Aws/StorageGateway/Enum/GatewayState.php!YR!۶+Aws/StorageGateway/Enum/GatewayTimezone.phpmYRm_'Aws/StorageGateway/Enum/GatewayType.phpYR"b(Aws/StorageGateway/Enum/VolumeStatus.phpYR|Rd&Aws/StorageGateway/Enum/VolumeType.php/YR/鰶=Aws/StorageGateway/Exception/InternalServerErrorException.php;YR;XΡy?Aws/StorageGateway/Exception/InvalidGatewayRequestException.phpVYRV,-8Aws/StorageGateway/Exception/StorageGatewayException.phpYRζ:Aws/StorageGateway/Resources/storagegateway-2013-06-30.phpYR0#$+Aws/StorageGateway/StorageGatewayClient.php"YR"Cߧ+Aws/Sts/Exception/ExpiredTokenException.php@YR@W24Aws/Sts/Exception/IDPCommunicationErrorException.php;YR;'c/Aws/Sts/Exception/IDPRejectedClaimException.phpYRB2Aws/Sts/Exception/IncompleteSignatureException.phpYR&.Aws/Sts/Exception/InternalFailureException.phpYRi,Aws/Sts/Exception/InvalidActionException.phpYRy޶:Aws/Sts/Exception/InvalidAuthorizationMessageException.php^YR^3Aws/Sts/Exception/InvalidClientTokenIdException.phpYR3Aws/Sts/Exception/InvalidIdentityTokenException.phpKYRKt:Aws/Sts/Exception/InvalidParameterCombinationException.phpYRl]S4Aws/Sts/Exception/InvalidParameterValueException.phpYRhrӶ4Aws/Sts/Exception/InvalidQueryParameterException.phpYR @6Aws/Sts/Exception/MalformedPolicyDocumentException.php,YR,uۜ3Aws/Sts/Exception/MalformedQueryStringException.phpYR3Y,Aws/Sts/Exception/MissingActionException.phpYRZ9Aws/Sts/Exception/MissingAuthenticationTokenException.phpYRrq/Aws/Sts/Exception/MissingParameterException.phpYRN,Aws/Sts/Exception/OptInRequiredException.phpYR%3Aws/Sts/Exception/PackedPolicyTooLargeException.phpmYRm5o/-Aws/Sts/Exception/RequestExpiredException.phpCYRCEb7?1Aws/Sts/Exception/ServiceUnavailableException.phpYRƪ"Aws/Sts/Exception/StsException.phpYR~۶)Aws/Sts/Exception/ThrottlingException.phpYRն,j$Aws/Sts/Resources/sts-2011-06-15.phpaYRa}Aws/Sts/StsClient.phpYR<Aws/Support/Exception/CaseCreationLimitExceededException.php YR 5|1Aws/Support/Exception/CaseIdNotFoundException.phpYR*︣6Aws/Support/Exception/InternalServerErrorException.phpYR۶*Aws/Support/Exception/SupportException.php YR F;1,Aws/Support/Resources/support-2013-04-15.phppYRpXAws/Support/SupportClient.phpYR\(Aws/Swf/Enum/ActivityTaskTimeoutType.phpYRB㯶Aws/Swf/Enum/ChildPolicy.phpCYRCS̶Aws/Swf/Enum/CloseStatus.phpYROX{4(Aws/Swf/Enum/DecisionTaskTimeoutType.phpYR^NAws/Swf/Enum/DecisionType.phpYR 0Aws/Swf/Enum/EventType.phpYRgz Aws/Swf/Enum/ExecutionStatus.phpYRϾ#Aws/Swf/Enum/RegistrationStatus.php,YR,h-Aws/Swf/Enum/WorkflowExecutionTimeoutType.php#YR#/Aws/Swf/Exception/DefaultUndefinedException.phpYRߐd2Aws/Swf/Exception/DomainAlreadyExistsException.php2YR2ুɶ/Aws/Swf/Exception/DomainDeprecatedException.phpYRG"ƶ,Aws/Swf/Exception/LimitExceededException.phpdYRd[d{v4Aws/Swf/Exception/OperationNotPermittedException.php YR zǒ"Aws/Swf/Exception/SwfException.phpYRH+0Aws/Swf/Exception/TypeAlreadyExistsException.phpYR"}-Aws/Swf/Exception/TypeDeprecatedException.phpYRP6.Aws/Swf/Exception/UnknownResourceException.phpYR`>Aws/Swf/Exception/WorkflowExecutionAlreadyStartedException.php?YR?x$Bö$Aws/Swf/Resources/swf-2012-01-25.phpYRYNAws/Swf/SwfClient.phpYR7)̶aws-autoloader.phphYRhX"Doctrine/Common/Cache/ApcCache.php YR N$Doctrine/Common/Cache/ArrayCache.php YR :Doctrine/Common/Cache/Cache.phpYR'Doctrine/Common/Cache/CacheProvider.phpwYRw3lY(Doctrine/Common/Cache/CouchbaseCache.phph YRh qbԶ#Doctrine/Common/Cache/FileCache.phpYRf)Doctrine/Common/Cache/FilesystemCache.php YR >'Doctrine/Common/Cache/MemcacheCache.phpY YRY P(Doctrine/Common/Cache/MemcachedCache.php YR Ha&Doctrine/Common/Cache/MongoDBCache.phpYR!lҶ&Doctrine/Common/Cache/PhpFileCache.php YR f>4$Doctrine/Common/Cache/RedisCache.php YR sW#Doctrine/Common/Cache/RiakCache.phpYR!Doctrine/Common/Cache/Version.php.YR.pG:'Doctrine/Common/Cache/WinCacheCache.phpo YRo 6Q%Doctrine/Common/Cache/XcacheCache.php) YR) k멶'Doctrine/Common/Cache/ZendDataCache.phpYR{B'Guzzle/Batch/AbstractBatchDecorator.phpYR?Guzzle/Batch/Batch.php YR sGuzzle/Batch/BatchBuilder.phpYR;Ͷ$Guzzle/Batch/BatchClosureDivisor.phptYRtzHF%Guzzle/Batch/BatchClosureTransfer.phpYRֶ%Guzzle/Batch/BatchCommandTransfer.phpYR2&Guzzle/Batch/BatchDivisorInterface.phpYR~Guzzle/Batch/BatchInterface.phpMYRMƿs|%Guzzle/Batch/BatchRequestTransfer.phpYRq;!Guzzle/Batch/BatchSizeDivisor.phpkYRkdj'Guzzle/Batch/BatchTransferInterface.phpYR#T1Guzzle/Batch/Exception/BatchTransferException.php YR &(Guzzle/Batch/ExceptionBufferingBatch.phpYRE$Guzzle/Batch/FlushingBatch.phpYRۆPGuzzle/Batch/HistoryBatch.phpYR`B2Guzzle/Batch/NotifyingBatch.phpYRj%Guzzle/Cache/AbstractCacheAdapter.phpGYRG!$Guzzle/Cache/CacheAdapterFactory.phpYR:ö&Guzzle/Cache/CacheAdapterInterface.phpYR$Guzzle/Cache/ClosureCacheAdapter.php^YR^ζ%Guzzle/Cache/DoctrineCacheAdapter.phpKYRK;#!Guzzle/Cache/NullCacheAdapter.phpYR Guzzle/Cache/Zf1CacheAdapter.phpYRZ㍼ Guzzle/Cache/Zf2CacheAdapter.phpYRI̶'Guzzle/Common/AbstractHasDispatcher.phpYR%;Guzzle/Common/Collection.php-YR-EGuzzle/Common/Event.php(YR(k۶2Guzzle/Common/Exception/BadMethodCallException.phpYRqS/Guzzle/Common/Exception/ExceptionCollection.php YR A˲+Guzzle/Common/Exception/GuzzleException.phpdYRdض4Guzzle/Common/Exception/InvalidArgumentException.phpYRVǶ,Guzzle/Common/Exception/RuntimeException.phpzYRzh^w4Guzzle/Common/Exception/UnexpectedValueException.phpYRe%Guzzle/Common/FromConfigInterface.phpYR1r(Guzzle/Common/HasDispatcherInterface.phpNYRN3"Guzzle/Common/ToArrayInterface.phpYRNGuzzle/Common/Version.phpYRNR+Guzzle/Http/AbstractEntityBodyDecorator.phpYRa!Guzzle/Http/CachingEntityBody.phpzYRzbGuzzle/Http/Client.phpAYRAzCGuzzle/Http/ClientInterface.php&YR&P g5Guzzle/Http/Curl/CurlHandle.phpj=YRj=n qGuzzle/Http/Curl/CurlMulti.php1YR11'Guzzle/Http/Curl/CurlMultiInterface.php=YR=њO#Guzzle/Http/Curl/CurlMultiProxy.phpGYRG|~ Guzzle/Http/Curl/CurlVersion.phpYR\$Guzzle/Http/Curl/RequestMediator.php]YR]TšGuzzle/Http/EntityBody.phpYRá#Guzzle/Http/EntityBodyInterface.phps YRs .Guzzle/Http/Exception/BadResponseException.php4YR4= 6Guzzle/Http/Exception/ClientErrorResponseException.phpYR5"ڶ7Guzzle/Http/Exception/CouldNotRewindStreamException.phpYRn'Guzzle/Http/Exception/CurlException.phpCYRC&Y'Guzzle/Http/Exception/HttpException.phpYR 0Guzzle/Http/Exception/MultiTransferException.php YR [ڒ*Guzzle/Http/Exception/RequestException.phpYRo~6Guzzle/Http/Exception/ServerErrorResponseException.phpYRWp3Guzzle/Http/Exception/TooManyRedirectsException.phpiYRiǸ$Guzzle/Http/IoEmittingEntityBody.phpYRc"'Guzzle/Http/Message/AbstractMessage.php#YR#C}#.Guzzle/Http/Message/EntityEnclosingRequest.phpYR'DU7Guzzle/Http/Message/EntityEnclosingRequestInterface.phpYR +Guzzle/Http/Message/Header/CacheControl.php YR O/Guzzle/Http/Message/Header/HeaderCollection.php YR hɶ,Guzzle/Http/Message/Header/HeaderFactory.phpYR┶5Guzzle/Http/Message/Header/HeaderFactoryInterface.phpYR.Guzzle/Http/Message/Header/HeaderInterface.phpPYRP(#Guzzle/Http/Message/Header/Link.phpYRGuzzle/Http/Message/Header.phpYRS(Guzzle/Http/Message/MessageInterface.php YR ۓ` Guzzle/Http/Message/PostFile.php YR M.>)Guzzle/Http/Message/PostFileInterface.phpYRӐ¶Guzzle/Http/Message/Request.phpKYRK&Guzzle/Http/Message/RequestFactory.php2YR2 J4/Guzzle/Http/Message/RequestFactoryInterface.phpxYRx&۶(Guzzle/Http/Message/RequestInterface.php7!YR7!Օ Guzzle/Http/Message/Response.phpfYRf礶Guzzle/Http/Mimetypes.phpYR/Guzzle/Http/QueryAggregator/CommaAggregator.phpYR^<Ͷ3Guzzle/Http/QueryAggregator/DuplicateAggregator.php<YR<9|\-Guzzle/Http/QueryAggregator/PhpAggregator.phptYRt$8Guzzle/Http/QueryAggregator/QueryAggregatorInterface.phpYR)Guzzle/Http/QueryString.phpYRe Զ#Guzzle/Http/ReadLimitEntityBody.php~ YR~ S왶Guzzle/Http/RedirectPlugin.php{'YR{'s; Guzzle/Http/Resources/cacert.pem~YR~{$Guzzle/Http/Resources/cacert.pem.md5!YR!1Guzzle/Http/StaticClient.php'YR'Z!Guzzle/Http/Url.php,8YR,8Guzzle/Inflection/Inflector.phpSYRSB#c(Guzzle/Inflection/InflectorInterface.php>YR>ָk(Guzzle/Inflection/MemoizingInflector.phpYRl_t*Guzzle/Inflection/PreComputedInflector.phpYR\:"Guzzle/Iterator/AppendIterator.phpYR#Guzzle/Iterator/ChunkedIterator.phpYRGZ"Guzzle/Iterator/FilterIterator.phpYRڬGuzzle/Iterator/MapIterator.phpTYRTR`1q'Guzzle/Iterator/MethodProxyIterator.phpbYRb]!Guzzle/Log/AbstractLogAdapter.php YR p-Guzzle/Log/ArrayLogAdapter.phpgYRgxc Guzzle/Log/ClosureLogAdapter.phpGYRG#p"Guzzle/Log/LogAdapterInterface.phpYR\:Guzzle/Log/MessageFormatter.phpYRB Guzzle/Log/MonologLogAdapter.phpYRLbȊGuzzle/Log/PsrLogAdapter.php^YR^Guzzle/Log/Zf1LogAdapter.phpYRYڶGuzzle/Log/Zf2LogAdapter.phpYR>'%Guzzle/Parser/Cookie/CookieParser.php YR |a.Guzzle/Parser/Cookie/CookieParserInterface.phpYR=/Guzzle/Parser/Message/AbstractMessageParser.phpYRJ2'Guzzle/Parser/Message/MessageParser.php YR ,0Guzzle/Parser/Message/MessageParserInterface.phpYR(5;/Guzzle/Parser/Message/PeclHttpMessageParser.phpYR Guzzle/Parser/ParserRegistry.phpYR-Guzzle/Parser/UriTemplate/PeclUriTemplate.phpYRQѶ)Guzzle/Parser/UriTemplate/UriTemplate.php YR Y2Guzzle/Parser/UriTemplate/UriTemplateInterface.phpYR[Guzzle/Parser/Url/UrlParser.phpYRloV2(Guzzle/Parser/Url/UrlParserInterface.phpYR"#Guzzle/Plugin/Async/AsyncPlugin.php YR `1Guzzle/Plugin/Backoff/AbstractBackoffStrategy.phpI YRI Z4:Guzzle/Plugin/Backoff/AbstractErrorCodeBackoffStrategy.phpYR|'Guzzle/Plugin/Backoff/BackoffLogger.php YR (*'Guzzle/Plugin/Backoff/BackoffPlugin.php=YR=Zm2Guzzle/Plugin/Backoff/BackoffStrategyInterface.phpYRX|1Guzzle/Plugin/Backoff/CallbackBackoffStrategy.phpYR>1Guzzle/Plugin/Backoff/ConstantBackoffStrategy.phpYR jv-Guzzle/Plugin/Backoff/CurlBackoffStrategy.phpYR%+4Guzzle/Plugin/Backoff/ExponentialBackoffStrategy.phpYRmhS-Guzzle/Plugin/Backoff/HttpBackoffStrategy.phpYR#Ǧ/Guzzle/Plugin/Backoff/LinearBackoffStrategy.phpYRT#5Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.phpYR sW2Guzzle/Plugin/Backoff/TruncatedBackoffStrategy.phpYRAQp1Guzzle/Plugin/Cache/CacheKeyProviderInterface.phpYRk˶#Guzzle/Plugin/Cache/CachePlugin.php:3YR:3P-Guzzle/Plugin/Cache/CacheStorageInterface.phpYR]90Guzzle/Plugin/Cache/CallbackCanCacheStrategy.phpYR,\p1Guzzle/Plugin/Cache/CanCacheStrategyInterface.phpYR[/Guzzle/Plugin/Cache/DefaultCacheKeyProvider.phpYRV+Guzzle/Plugin/Cache/DefaultCacheStorage.php2YR2@/Guzzle/Plugin/Cache/DefaultCanCacheStrategy.phpYR+Guzzle/Plugin/Cache/DefaultRevalidation.phpYRA(Guzzle/Plugin/Cache/DenyRevalidation.phpYR-Guzzle/Plugin/Cache/RevalidationInterface.phpNYRND(Guzzle/Plugin/Cache/SkipRevalidation.phpYRNtGuzzle/Plugin/Cookie/Cookie.php-YR-Y1Guzzle/Plugin/Cookie/CookieJar/ArrayCookieJar.php4YR4YO5Guzzle/Plugin/Cookie/CookieJar/CookieJarInterface.phpj YRj 4`۶0Guzzle/Plugin/Cookie/CookieJar/FileCookieJar.phpYRt2L%Guzzle/Plugin/Cookie/CookiePlugin.phpYRL"]9Guzzle/Plugin/Cookie/Exception/InvalidCookieException.phpYR!m|)Guzzle/Plugin/CurlAuth/CurlAuthPlugin.phplYRl˞?Guzzle/Plugin/ErrorResponse/ErrorResponseExceptionInterface.phpVYRV|F3Guzzle/Plugin/ErrorResponse/ErrorResponsePlugin.php YR @Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.phpYRҙ'Guzzle/Plugin/History/HistoryPlugin.phpQYRQDS+Guzzle/Plugin/Log/LogPlugin.phpYRA"ڶ-Guzzle/Plugin/Md5/CommandContentMd5Plugin.phpYR'f(Guzzle/Plugin/Md5/Md5ValidatorPlugin.phpu YRu Nm!Guzzle/Plugin/Mock/MockPlugin.phpYR* #Guzzle/Plugin/Oauth/OauthPlugin.php'YR'ӤL'Guzzle/Service/AbstractConfigLoader.phpqYRq7)Guzzle/Service/Builder/ServiceBuilder.phpYR2Guzzle/Service/Builder/ServiceBuilderInterface.phpYRS)/Guzzle/Service/Builder/ServiceBuilderLoader.phpD YRD _&Guzzle/Service/CachingConfigLoader.phpYRGuzzle/Service/Client.phpG$YRG$.eY"Guzzle/Service/ClientInterface.php YR *Guzzle/Service/Command/AbstractCommand.php40YR40Qb)Guzzle/Service/Command/ClosureCommand.phpYR.+Guzzle/Service/Command/CommandInterface.php YR %3Guzzle/Service/Command/CreateResponseClassEvent.php<YR< 8+3Guzzle/Service/Command/DefaultRequestSerializer.phpYR9[0Guzzle/Service/Command/DefaultResponseParser.phpYR.'|/Guzzle/Service/Command/Factory/AliasFactory.php`YR`d3Guzzle/Service/Command/Factory/CompositeFactory.phpYRj1̶7Guzzle/Service/Command/Factory/ConcreteClassFactory.phpEYRE=3Guzzle/Service/Command/Factory/FactoryInterface.phpYRϠYc-Guzzle/Service/Command/Factory/MapFactory.phpYR <Guzzle/Service/Command/Factory/ServiceDescriptionFactory.phpmYRmIGuzzle/Service/Command/LocationVisitor/Request/AbstractRequestVisitor.phpYRZv>Guzzle/Service/Command/LocationVisitor/Request/BodyVisitor.php YR Y4@Guzzle/Service/Command/LocationVisitor/Request/HeaderVisitor.phpYR ϶q>Guzzle/Service/Command/LocationVisitor/Request/JsonVisitor.phpYRa CGuzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php YR ˱ԶBGuzzle/Service/Command/LocationVisitor/Request/PostFileVisitor.phpYR$p?Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.phpYR=JGuzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php7YR7{HƶFGuzzle/Service/Command/LocationVisitor/Request/ResponseBodyVisitor.phpYRV=Guzzle/Service/Command/LocationVisitor/Request/XmlVisitor.phpYR KGuzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.phpfYRf}M?Guzzle/Service/Command/LocationVisitor/Response/BodyVisitor.php3YR3AGuzzle/Service/Command/LocationVisitor/Response/HeaderVisitor.phpYRտ?Guzzle/Service/Command/LocationVisitor/Response/JsonVisitor.php YR 貶GGuzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.phpHYRH1LGuzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php2YR2[EGuzzle/Service/Command/LocationVisitor/Response/StatusCodeVisitor.phpBYRBx@>Guzzle/Service/Command/LocationVisitor/Response/XmlVisitor.phprYRr4E;Guzzle/Service/Command/LocationVisitor/VisitorFlyweight.phpYRQ+Guzzle/Service/Command/OperationCommand.php YR Y2Guzzle/Service/Command/OperationResponseParser.phpYRR5Guzzle/Service/Command/RequestSerializerInterface.phpYRÖEk1Guzzle/Service/Command/ResponseClassInterface.phpYRso2Guzzle/Service/Command/ResponseParserInterface.phpYRw{(Guzzle/Service/ConfigLoaderInterface.phpYRVQh(Guzzle/Service/Description/Operation.phpv=YRv=_މ1Guzzle/Service/Description/OperationInterface.phpYRe (Guzzle/Service/Description/Parameter.phpaYRa[.Guzzle/Service/Description/SchemaFormatter.phpYR/lF.Guzzle/Service/Description/SchemaValidator.phpP.YRP.m1Guzzle/Service/Description/ServiceDescription.phpYR#Ŷ:Guzzle/Service/Description/ServiceDescriptionInterface.phpYR/S7Guzzle/Service/Description/ServiceDescriptionLoader.php YR %@1Guzzle/Service/Description/ValidatorInterface.phpYRb-Guzzle/Service/Exception/CommandException.phpYRկ5Guzzle/Service/Exception/CommandTransferException.php YR V϶8Guzzle/Service/Exception/DescriptionBuilderException.phpYRƣ@Guzzle/Service/Exception/InconsistentClientTransferException.phpYRy 3Guzzle/Service/Exception/ResponseClassException.phpYR#N4Guzzle/Service/Exception/ServiceBuilderException.phpYRNζ5Guzzle/Service/Exception/ServiceNotFoundException.phpnYRnSh0Guzzle/Service/Exception/ValidationException.phpYRbd;Guzzle/Service/Resource/AbstractResourceIteratorFactory.phpYR`<Guzzle/Service/Resource/CompositeResourceIteratorFactory.phpYR쾒6Guzzle/Service/Resource/MapResourceIteratorFactory.phpYR!Guzzle/Service/Resource/Model.phpYRBpQ,Guzzle/Service/Resource/ResourceIterator.php\YR\K˶8Guzzle/Service/Resource/ResourceIteratorApplyBatched.phpS YRS ֜8Guzzle/Service/Resource/ResourceIteratorClassFactory.phpYRq<Guzzle/Service/Resource/ResourceIteratorFactoryInterface.phpYR癤Ѷ5Guzzle/Service/Resource/ResourceIteratorInterface.phpYR2P)Guzzle/Stream/PhpStreamRequestFactory.php$YR$9Guzzle/Stream/Stream.phpYR Ķ!Guzzle/Stream/StreamInterface.php8YR81/Guzzle/Stream/StreamRequestFactoryInterface.php[YR[4(Monolog/Formatter/ChromePHPFormatter.phpYRlD(Monolog/Formatter/FormatterInterface.phpYRWܑ*Monolog/Formatter/GelfMessageFormatter.php} YR} #Monolog/Formatter/JsonFormatter.phpYRe#Monolog/Formatter/LineFormatter.php YR !_'Monolog/Formatter/LogstashFormatter.phpR YRR Őʶ)Monolog/Formatter/NormalizerFormatter.php YR *)'Monolog/Formatter/WildfireFormatter.phpb YRb 6$#Monolog/Handler/AbstractHandler.php0YR0p-Monolog/Handler/AbstractProcessingHandler.phpYR3GMonolog/Handler/AmqpHandler.phplYRl ̶!Monolog/Handler/BufferHandler.php4 YR4 O1$Monolog/Handler/ChromePHPHandler.phpYR\5)"Monolog/Handler/CouchDBHandler.php{YR{nMonolog/Handler/CubeHandler.php YR A˾*Monolog/Handler/DoctrineCouchDBHandler.phpYR~>Monolog/Handler/FingersCrossed/ActivationStrategyInterface.phpYRS?Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.phpYRJHi)Monolog/Handler/FingersCrossedHandler.phpYRw"Monolog/Handler/FirePHPHandler.php~YR~kMonolog/Handler/GelfHandler.phpgYRgc Monolog/Handler/GroupHandler.phpaYRae}ζ$Monolog/Handler/HandlerInterface.php YR |_Monolog/Handler/MailHandler.phpYR Ja-Monolog/Handler/MissingExtensionException.phpYR8?"Monolog/Handler/MongoDBHandler.phplYRl'Monolog/Handler/NativeMailerHandler.phpYR6 Monolog/Handler/NullHandler.phpYRO#Monolog/Handler/PushoverHandler.php YR +{ Monolog/Handler/RavenHandler.phpf YRf 93޶ Monolog/Handler/RedisHandler.phpYR U'Monolog/Handler/RotatingFileHandler.phpYR X!Monolog/Handler/SocketHandler.phpYR!Monolog/Handler/StreamHandler.phpYR!&Monolog/Handler/SwiftMailerHandler.phpYRk!Monolog/Handler/SyslogHandler.php}YR}OQR?Monolog/Handler/TestHandler.php YR ~V͚&Monolog/Handler/ZendMonitorHandler.phpYRmcMonolog/Logger.php=YR=T,Monolog/Processor/IntrospectionProcessor.phpYR.Monolog/Processor/MemoryPeakUsageProcessor.php~YR~'%Monolog/Processor/MemoryProcessor.phpYR0p*Monolog/Processor/MemoryUsageProcessor.phpkYRk%,Monolog/Processor/PsrLogMessageProcessor.phpYR񀫶"Monolog/Processor/WebProcessor.phpYRAPsr/Log/AbstractLogger.php YR ,$Psr/Log/InvalidArgumentException.php`YR` X1 Psr/Log/LoggerAwareInterface.php YR SjTPsr/Log/LoggerAwareTrait.php_YR_b޶Psr/Log/LoggerInterface.php YR bPsr/Log/LoggerTrait.php YR =Psr/Log/LogLevel.php8YR8l$ӥPsr/Log/NullLogger.phpYR>$Psr/Log/Test/LoggerInterfaceTest.php"YR"0Symfony/Component/ClassLoader/ApcClassLoader.phpYRlOݶ9Symfony/Component/ClassLoader/ApcUniversalClassLoader.php YR a7Symfony/Component/ClassLoader/ClassCollectionLoader.php .YR .v-Symfony/Component/ClassLoader/ClassLoader.phpYRv'3Symfony/Component/ClassLoader/ClassMapGenerator.php YR ?wy2Symfony/Component/ClassLoader/DebugClassLoader.php YR S;Symfony/Component/ClassLoader/DebugUniversalClassLoader.php)YR)w!0Symfony/Component/ClassLoader/MapClassLoader.phpYRACSymfony/Component/ClassLoader/Tests/ApcUniversalClassLoaderTest.phpYRe:{aASymfony/Component/ClassLoader/Tests/ClassCollectionLoaderTest.php YR ]Q7Symfony/Component/ClassLoader/Tests/ClassLoaderTest.php YR Mȶ=Symfony/Component/ClassLoader/Tests/ClassMapGeneratorTest.phpYR\|ͶOSymfony/Component/ClassLoader/Tests/Fixtures/alpha/NamespaceCollision/A/Bar.php?YR?99AOSymfony/Component/ClassLoader/Tests/Fixtures/alpha/NamespaceCollision/A/Foo.php?YR?iOSymfony/Component/ClassLoader/Tests/Fixtures/alpha/NamespaceCollision/C/Bar.phpXYRX]>OSymfony/Component/ClassLoader/Tests/Fixtures/alpha/NamespaceCollision/C/Foo.phpXYRX~(LSymfony/Component/ClassLoader/Tests/Fixtures/alpha/PrefixCollision/A/Bar.phpIYRI&FLSymfony/Component/ClassLoader/Tests/Fixtures/alpha/PrefixCollision/A/Foo.phpIYRILSymfony/Component/ClassLoader/Tests/Fixtures/alpha/PrefixCollision/C/Bar.phpIYRI6SLSymfony/Component/ClassLoader/Tests/Fixtures/alpha/PrefixCollision/C/Foo.phpIYRI ̶WSymfony/Component/ClassLoader/Tests/Fixtures/Apc/alpha/Apc/ApcPrefixCollision/A/Bar.phpLYRL7WSymfony/Component/ClassLoader/Tests/Fixtures/Apc/alpha/Apc/ApcPrefixCollision/A/Foo.phpLYRL.&WSymfony/Component/ClassLoader/Tests/Fixtures/Apc/alpha/Apc/NamespaceCollision/A/Bar.phpCYRC4޶WSymfony/Component/ClassLoader/Tests/Fixtures/Apc/alpha/Apc/NamespaceCollision/A/Foo.phpCYRCqoXSymfony/Component/ClassLoader/Tests/Fixtures/Apc/beta/Apc/ApcPrefixCollision/A/B/Bar.phpNYRN>\oXSymfony/Component/ClassLoader/Tests/Fixtures/Apc/beta/Apc/ApcPrefixCollision/A/B/Foo.phpNYRNGXSymfony/Component/ClassLoader/Tests/Fixtures/Apc/beta/Apc/NamespaceCollision/A/B/Bar.phpEYREF彶XSymfony/Component/ClassLoader/Tests/Fixtures/Apc/beta/Apc/NamespaceCollision/A/B/Foo.phpEYRE][QSymfony/Component/ClassLoader/Tests/Fixtures/Apc/fallback/Apc/Pearlike/FooBar.phpGYRGOSymfony/Component/ClassLoader/Tests/Fixtures/Apc/fallback/Namespaced/FooBar.php<YR</5CSymfony/Component/ClassLoader/Tests/Fixtures/Apc/Namespaced/Bar.php9YR9ےCSymfony/Component/ClassLoader/Tests/Fixtures/Apc/Namespaced/Baz.php9YR9$yCSymfony/Component/ClassLoader/Tests/Fixtures/Apc/Namespaced/Foo.php9YR90- +FSymfony/Component/ClassLoader/Tests/Fixtures/Apc/Namespaced/FooBar.php<YR</5ASymfony/Component/ClassLoader/Tests/Fixtures/Apc/Pearlike/Bar.phpDYRDyQUmASymfony/Component/ClassLoader/Tests/Fixtures/Apc/Pearlike/Baz.phpDYRD&ASymfony/Component/ClassLoader/Tests/Fixtures/Apc/Pearlike/Foo.phpDYRDEPSymfony/Component/ClassLoader/Tests/Fixtures/beta/NamespaceCollision/A/B/Bar.phpAYRAKaöPSymfony/Component/ClassLoader/Tests/Fixtures/beta/NamespaceCollision/A/B/Foo.phpAYRAPSymfony/Component/ClassLoader/Tests/Fixtures/beta/NamespaceCollision/C/B/Bar.phpZYRZcPSymfony/Component/ClassLoader/Tests/Fixtures/beta/NamespaceCollision/C/B/Foo.phpZYRZLVAKMSymfony/Component/ClassLoader/Tests/Fixtures/beta/PrefixCollision/A/B/Bar.phpKYRKLkMSymfony/Component/ClassLoader/Tests/Fixtures/beta/PrefixCollision/A/B/Foo.phpKYRKvգMSymfony/Component/ClassLoader/Tests/Fixtures/beta/PrefixCollision/C/B/Bar.phpKYRK{tMSymfony/Component/ClassLoader/Tests/Fixtures/beta/PrefixCollision/C/B/Foo.phpKYRKPF\ESymfony/Component/ClassLoader/Tests/Fixtures/ClassesWithParents/A.php;YR; JSymfony/Component/ClassLoader/Tests/Fixtures/ClassesWithParents/ATrait.php7YR7 NESymfony/Component/ClassLoader/Tests/Fixtures/ClassesWithParents/B.phpGYRGLqJSymfony/Component/ClassLoader/Tests/Fixtures/ClassesWithParents/BTrait.phpGYRGHNSymfony/Component/ClassLoader/Tests/Fixtures/ClassesWithParents/CInterface.phpRYRR`ŶJSymfony/Component/ClassLoader/Tests/Fixtures/ClassesWithParents/CTrait.php7YR7["ESymfony/Component/ClassLoader/Tests/Fixtures/ClassesWithParents/D.phpLYRL ESymfony/Component/ClassLoader/Tests/Fixtures/ClassesWithParents/E.phpLYRLtɶNSymfony/Component/ClassLoader/Tests/Fixtures/ClassesWithParents/GInterface.php?YR?ZDSymfony/Component/ClassLoader/Tests/Fixtures/classmap/multipleNs.phpYRKG9նCSymfony/Component/ClassLoader/Tests/Fixtures/classmap/notAClass.phpYRiOSymfony/Component/ClassLoader/Tests/Fixtures/classmap/sameNsMultipleClasses.phpYRҚCSymfony/Component/ClassLoader/Tests/Fixtures/classmap/SomeClass.phpDYRD.~oGSymfony/Component/ClassLoader/Tests/Fixtures/classmap/SomeInterface.php YR ֡ZDSymfony/Component/ClassLoader/Tests/Fixtures/classmap/SomeParent.php"YR"Cq<Symfony/Component/ClassLoader/Tests/Fixtures/deps/traits.phpYR>XKSymfony/Component/ClassLoader/Tests/Fixtures/fallback/Namespaced/FooBar.php8YR8[“LSymfony/Component/ClassLoader/Tests/Fixtures/fallback/Namespaced2/FooBar.phpRYRRgyISymfony/Component/ClassLoader/Tests/Fixtures/fallback/Pearlike/FooBar.phpCYRCxwJSymfony/Component/ClassLoader/Tests/Fixtures/fallback/Pearlike2/FooBar.phpDYRDn@Symfony/Component/ClassLoader/Tests/Fixtures/includepath/Foo.phpYRd?Symfony/Component/ClassLoader/Tests/Fixtures/Namespaced/Bar.php5YR5ƶ?Symfony/Component/ClassLoader/Tests/Fixtures/Namespaced/Baz.php5YR5ᒟ?Symfony/Component/ClassLoader/Tests/Fixtures/Namespaced/Foo.php5YR5RHSymfony/Component/ClassLoader/Tests/Fixtures/Namespaced/WithComments.phpYRUXƶ@Symfony/Component/ClassLoader/Tests/Fixtures/Namespaced2/Bar.phpOYRO@@Symfony/Component/ClassLoader/Tests/Fixtures/Namespaced2/Baz.phpOYRO Z3b@Symfony/Component/ClassLoader/Tests/Fixtures/Namespaced2/Foo.phpOYROd0=Symfony/Component/ClassLoader/Tests/Fixtures/Pearlike/Bar.php@YR@l=Symfony/Component/ClassLoader/Tests/Fixtures/Pearlike/Baz.php@YR@q=Symfony/Component/ClassLoader/Tests/Fixtures/Pearlike/Foo.php@YR@ӼFSymfony/Component/ClassLoader/Tests/Fixtures/Pearlike/WithComments.phpDYRD5Jƶ>Symfony/Component/ClassLoader/Tests/Fixtures/Pearlike2/Bar.phpAYRAh4A!>Symfony/Component/ClassLoader/Tests/Fixtures/Pearlike2/Baz.phpAYRA2[>Symfony/Component/ClassLoader/Tests/Fixtures/Pearlike2/Foo.phpAYRA >Symfony/Component/ClassLoader/Tests/Fixtures/php5.4/traits.phpYR:5T+@Symfony/Component/ClassLoader/Tests/UniversalClassLoaderTest.php#YR#8`Ͷ6Symfony/Component/ClassLoader/UniversalClassLoader.phpe"YRe"a.5Symfony/Component/ClassLoader/WinCacheClassLoader.phpYRO3Symfony/Component/ClassLoader/XcacheClassLoader.php YR YCSymfony/Component/EventDispatcher/ContainerAwareEventDispatcher.phpYRNmMSymfony/Component/EventDispatcher/Debug/TraceableEventDispatcherInterface.phpYR +Symfony/Component/EventDispatcher/Event.php YR bk5Symfony/Component/EventDispatcher/EventDispatcher.phpYRY">Symfony/Component/EventDispatcher/EventDispatcherInterface.php YR UҶ>Symfony/Component/EventDispatcher/EventSubscriberInterface.php1YR1cG2Symfony/Component/EventDispatcher/GenericEvent.phpDYRD,>Symfony/Component/EventDispatcher/ImmutableEventDispatcher.phpYRs MSymfony/Component/EventDispatcher/Tests/ContainerAwareEventDispatcherTest.phpYR'm?Symfony/Component/EventDispatcher/Tests/EventDispatcherTest.phpq/YRq/c p5Symfony/Component/EventDispatcher/Tests/EventTest.phpYRnu<Symfony/Component/EventDispatcher/Tests/GenericEventTest.php YR \2HSymfony/Component/EventDispatcher/Tests/ImmutableEventDispatcherTest.php YR +̶setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/autoscaling-%s.php' )) ->build(); } } '2011-01-01', 'endpointPrefix' => 'autoscaling', 'serviceFullName' => 'Auto Scaling', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'AutoScaling', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'autoscaling.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AttachInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceIds.member', 'items' => array( 'name' => 'XmlStringMaxLen16', 'type' => 'string', 'minLength' => 1, 'maxLength' => 16, ), ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'CreateAutoScalingGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateAutoScalingGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'LaunchConfigurationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16, ), 'MinSize' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxSize' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'DesiredCapacity' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DefaultCooldown' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'minItems' => 1, 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'LoadBalancerNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LoadBalancerNames.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'HealthCheckType' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 32, ), 'HealthCheckGracePeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PlacementGroup' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'VPCZoneIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'TerminationPolicies' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'TerminationPolicies.member', 'items' => array( 'name' => 'XmlStringMaxLen1600', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 128, ), 'Value' => array( 'type' => 'string', 'maxLength' => 256, ), 'PropagateAtLaunch' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The named Auto Scaling group or launch configuration already exists.', 'class' => 'AlreadyExistsException', ), array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'CreateLaunchConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLaunchConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'LaunchConfigurationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'ImageId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'KeyName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'SecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroups.member', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), 'UserData' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 21847, ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16, ), 'InstanceType' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'KernelId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'RamdiskId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMappings.member', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'DeviceName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'VolumeSize' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 1024, ), 'VolumeType' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'Iops' => array( 'type' => 'numeric', 'minimum' => 100, 'maximum' => 4000, ), ), ), 'NoDevice' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'InstanceMonitoring' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'SpotPrice' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'IamInstanceProfile' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'EbsOptimized' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The named Auto Scaling group or launch configuration already exists.', 'class' => 'AlreadyExistsException', ), array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'CreateOrUpdateTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateOrUpdateTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'Tags' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 128, ), 'Value' => array( 'type' => 'string', 'maxLength' => 256, ), 'PropagateAtLaunch' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The named Auto Scaling group or launch configuration already exists.', 'class' => 'AlreadyExistsException', ), ), ), 'DeleteAutoScalingGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAutoScalingGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ForceDelete' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), array( 'reason' => 'This is returned when you cannot delete a launch configuration or Auto Scaling group because it is being used.', 'class' => 'ResourceInUseException', ), ), ), 'DeleteLaunchConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLaunchConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'LaunchConfigurationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), 'errorResponses' => array( array( 'reason' => 'This is returned when you cannot delete a launch configuration or Auto Scaling group because it is being used.', 'class' => 'ResourceInUseException', ), ), ), 'DeleteNotificationConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteNotificationConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'TopicARN' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'DeletePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeletePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'DeleteScheduledAction' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteScheduledAction', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScheduledActionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'DeleteTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'Tags' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 128, ), 'Value' => array( 'type' => 'string', 'maxLength' => 256, ), 'PropagateAtLaunch' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), ), 'DescribeAccountLimits' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAccountLimitsAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAccountLimits', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeAdjustmentTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAdjustmentTypesAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAdjustmentTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeAutoScalingGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AutoScalingGroupsType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAutoScalingGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AutoScalingGroupNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeAutoScalingInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AutoScalingInstancesType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAutoScalingInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceIds.member', 'items' => array( 'name' => 'XmlStringMaxLen16', 'type' => 'string', 'minLength' => 1, 'maxLength' => 16, ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeAutoScalingNotificationTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAutoScalingNotificationTypesAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAutoScalingNotificationTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeLaunchConfigurations' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'LaunchConfigurationsType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLaunchConfigurations', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'LaunchConfigurationNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LaunchConfigurationNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeMetricCollectionTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeMetricCollectionTypesAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeMetricCollectionTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeNotificationConfigurations' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeNotificationConfigurationsAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeNotificationConfigurations', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AutoScalingGroupNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribePolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'PoliciesType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribePolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'PolicyNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeScalingActivities' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ActivitiesType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeScalingActivities', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'ActivityIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ActivityIds.member', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeScalingProcessTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ProcessesType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeScalingProcessTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DescribeScheduledActions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ScheduledActionsType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeScheduledActions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScheduledActionNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ScheduledActionNames.member', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'TagsType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Values.member', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'The NextToken value is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeTerminationPolicyTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeTerminationPolicyTypesAnswer', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeTerminationPolicyTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), ), ), 'DisableMetricsCollection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableMetricsCollection', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'Metrics' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Metrics.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'EnableMetricsCollection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableMetricsCollection', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'Metrics' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Metrics.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'Granularity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), ), ), 'ExecutePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ExecutePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'HonorCooldown' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), ), ), 'PutNotificationConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutNotificationConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'TopicARN' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'NotificationTypes' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NotificationTypes.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), 'errorResponses' => array( array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'PutScalingPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'PolicyARNType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutScalingPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'ScalingAdjustment' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'AdjustmentType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Cooldown' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MinAdjustmentStep' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'PutScheduledUpdateGroupAction' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutScheduledUpdateGroupAction', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScheduledActionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Time' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Recurrence' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'MinSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DesiredCapacity' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The named Auto Scaling group or launch configuration already exists.', 'class' => 'AlreadyExistsException', ), array( 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'ResumeProcesses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResumeProcesses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScalingProcesses' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ScalingProcesses.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'SetDesiredCapacity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetDesiredCapacity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'DesiredCapacity' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'HonorCooldown' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), ), ), 'SetInstanceHealth' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetInstanceHealth', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16, ), 'HealthStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 32, ), 'ShouldRespectGracePeriod' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'SuspendProcesses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SuspendProcesses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'ScalingProcesses' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ScalingProcesses.member', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'TerminateInstanceInAutoScalingGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ActivityType', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'TerminateInstanceInAutoScalingGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16, ), 'ShouldDecrementDesiredCapacity' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), ), ), 'UpdateAutoScalingGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateAutoScalingGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-01-01', ), 'AutoScalingGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'LaunchConfigurationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1600, ), 'MinSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DesiredCapacity' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DefaultCooldown' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'minItems' => 1, 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'HealthCheckType' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 32, ), 'HealthCheckGracePeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PlacementGroup' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'VPCZoneIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'TerminationPolicies' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'TerminationPolicies.member', 'items' => array( 'name' => 'XmlStringMaxLen1600', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1600, ), ), ), 'errorResponses' => array( array( 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', 'class' => 'ScalingActivityInProgressException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeAccountLimitsAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MaxNumberOfAutoScalingGroups' => array( 'type' => 'numeric', 'location' => 'xml', ), 'MaxNumberOfLaunchConfigurations' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'DescribeAdjustmentTypesAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AdjustmentTypes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AdjustmentType', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AdjustmentType' => array( 'type' => 'string', ), ), ), ), ), ), 'AutoScalingGroupsType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AutoScalingGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AutoScalingGroup', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AutoScalingGroupName' => array( 'type' => 'string', ), 'AutoScalingGroupARN' => array( 'type' => 'string', ), 'LaunchConfigurationName' => array( 'type' => 'string', ), 'MinSize' => array( 'type' => 'numeric', ), 'MaxSize' => array( 'type' => 'numeric', ), 'DesiredCapacity' => array( 'type' => 'numeric', ), 'DefaultCooldown' => array( 'type' => 'numeric', ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'sentAs' => 'member', ), ), 'LoadBalancerNames' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'sentAs' => 'member', ), ), 'HealthCheckType' => array( 'type' => 'string', ), 'HealthCheckGracePeriod' => array( 'type' => 'numeric', ), 'Instances' => array( 'type' => 'array', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'LifecycleState' => array( 'type' => 'string', ), 'HealthStatus' => array( 'type' => 'string', ), 'LaunchConfigurationName' => array( 'type' => 'string', ), ), ), ), 'CreatedTime' => array( 'type' => 'string', ), 'SuspendedProcesses' => array( 'type' => 'array', 'items' => array( 'name' => 'SuspendedProcess', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ProcessName' => array( 'type' => 'string', ), 'SuspensionReason' => array( 'type' => 'string', ), ), ), ), 'PlacementGroup' => array( 'type' => 'string', ), 'VPCZoneIdentifier' => array( 'type' => 'string', ), 'EnabledMetrics' => array( 'type' => 'array', 'items' => array( 'name' => 'EnabledMetric', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Metric' => array( 'type' => 'string', ), 'Granularity' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), 'Tags' => array( 'type' => 'array', 'items' => array( 'name' => 'TagDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'PropagateAtLaunch' => array( 'type' => 'boolean', ), ), ), ), 'TerminationPolicies' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlStringMaxLen1600', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'AutoScalingInstancesType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AutoScalingInstances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AutoScalingInstanceDetails', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'AutoScalingGroupName' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'LifecycleState' => array( 'type' => 'string', ), 'HealthStatus' => array( 'type' => 'string', ), 'LaunchConfigurationName' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeAutoScalingNotificationTypesAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AutoScalingNotificationTypes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'XmlStringMaxLen255', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'LaunchConfigurationsType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LaunchConfigurations' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'LaunchConfiguration', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'LaunchConfigurationName' => array( 'type' => 'string', ), 'LaunchConfigurationARN' => array( 'type' => 'string', ), 'ImageId' => array( 'type' => 'string', ), 'KeyName' => array( 'type' => 'string', ), 'SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'sentAs' => 'member', ), ), 'UserData' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'KernelId' => array( 'type' => 'string', ), 'RamdiskId' => array( 'type' => 'string', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'VolumeType' => array( 'type' => 'string', ), 'DeleteOnTermination' => array( 'type' => 'boolean', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'boolean', ), ), ), ), 'InstanceMonitoring' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), ), ), 'SpotPrice' => array( 'type' => 'string', ), 'IamInstanceProfile' => array( 'type' => 'string', ), 'CreatedTime' => array( 'type' => 'string', ), 'EbsOptimized' => array( 'type' => 'boolean', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeMetricCollectionTypesAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Metrics' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MetricCollectionType', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Metric' => array( 'type' => 'string', ), ), ), ), 'Granularities' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MetricGranularityType', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Granularity' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeNotificationConfigurationsAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NotificationConfigurations' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'NotificationConfiguration', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AutoScalingGroupName' => array( 'type' => 'string', ), 'TopicARN' => array( 'type' => 'string', ), 'NotificationType' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'PoliciesType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ScalingPolicies' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ScalingPolicy', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AutoScalingGroupName' => array( 'type' => 'string', ), 'PolicyName' => array( 'type' => 'string', ), 'ScalingAdjustment' => array( 'type' => 'numeric', ), 'AdjustmentType' => array( 'type' => 'string', ), 'Cooldown' => array( 'type' => 'numeric', ), 'PolicyARN' => array( 'type' => 'string', ), 'Alarms' => array( 'type' => 'array', 'items' => array( 'name' => 'Alarm', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AlarmName' => array( 'type' => 'string', ), 'AlarmARN' => array( 'type' => 'string', ), ), ), ), 'MinAdjustmentStep' => array( 'type' => 'numeric', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ActivitiesType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Activities' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Activity', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ActivityId' => array( 'type' => 'string', ), 'AutoScalingGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Cause' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'EndTime' => array( 'type' => 'string', ), 'StatusCode' => array( 'type' => 'string', ), 'StatusMessage' => array( 'type' => 'string', ), 'Progress' => array( 'type' => 'numeric', ), 'Details' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ProcessesType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Processes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ProcessType', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ProcessName' => array( 'type' => 'string', ), ), ), ), ), ), 'ScheduledActionsType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ScheduledUpdateGroupActions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ScheduledUpdateGroupAction', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AutoScalingGroupName' => array( 'type' => 'string', ), 'ScheduledActionName' => array( 'type' => 'string', ), 'ScheduledActionARN' => array( 'type' => 'string', ), 'Time' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'EndTime' => array( 'type' => 'string', ), 'Recurrence' => array( 'type' => 'string', ), 'MinSize' => array( 'type' => 'numeric', ), 'MaxSize' => array( 'type' => 'numeric', ), 'DesiredCapacity' => array( 'type' => 'numeric', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'TagsType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Tags' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'TagDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'PropagateAtLaunch' => array( 'type' => 'boolean', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeTerminationPolicyTypesAnswer' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TerminationPolicyTypes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'XmlStringMaxLen1600', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'PolicyARNType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyARN' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ActivityType' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Activity' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'ActivityId' => array( 'type' => 'string', ), 'AutoScalingGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Cause' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'EndTime' => array( 'type' => 'string', ), 'StatusCode' => array( 'type' => 'string', ), 'StatusMessage' => array( 'type' => 'string', ), 'Progress' => array( 'type' => 'numeric', ), 'Details' => array( 'type' => 'string', ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeAutoScalingGroups' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'AutoScalingGroups', ), 'DescribeAutoScalingInstances' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'AutoScalingInstances', ), 'DescribeLaunchConfigurations' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'LaunchConfigurations', ), 'DescribeNotificationConfigurations' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'NotificationConfigurations', ), 'DescribePolicies' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'ScalingPolicies', ), 'DescribeScalingActivities' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'Activities', ), 'DescribeScheduledActions' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'ScheduledUpdateGroupActions', ), 'DescribeTags' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'Tags', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudformation-%s.php' )) ->build(); } } '2010-05-15', 'endpointPrefix' => 'cloudformation', 'serviceFullName' => 'AWS CloudFormation', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'CloudFormation', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudformation.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'CancelUpdateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelUpdateStack', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateStackOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateStack', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TemplateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), 'TemplateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), 'DisableRollback' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'TimeoutInMinutes' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, ), 'NotificationARNs' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NotificationARNs.member', 'maxItems' => 5, 'items' => array( 'name' => 'NotificationARN', 'type' => 'string', ), ), 'Capabilities' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Capabilities.member', 'items' => array( 'name' => 'Capability', 'type' => 'string', ), ), 'OnFailure' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StackPolicyBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'StackPolicyURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1350, ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Quota for the resource has already been reached.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Resource with the name requested already exists.', 'class' => 'AlreadyExistsException', ), array( 'reason' => 'The template contains resources with capabilities that were not specified in the Capabilities parameter.', 'class' => 'InsufficientCapabilitiesException', ), ), ), 'DeleteStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteStack', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeStackEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStackEventsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStackEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), ), ), 'DescribeStackResource' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStackResourceOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStackResource', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LogicalResourceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeStackResources' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStackResourcesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStackResources', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LogicalResourceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PhysicalResourceId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeStacks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStacksOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStacks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), ), ), 'EstimateTemplateCost' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EstimateTemplateCostOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EstimateTemplateCost', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'TemplateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), 'TemplateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), ), ), 'GetStackPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetStackPolicyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetStackPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetTemplateOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ListStackResources' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListStackResourcesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListStackResources', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), ), ), 'ListStacks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListStacksOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListStacks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'StackStatusFilter' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'StackStatusFilter.member', 'items' => array( 'name' => 'StackStatus', 'type' => 'string', ), ), ), ), 'SetStackPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetStackPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'StackPolicyBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'StackPolicyURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1350, ), ), ), 'UpdateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateStackOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateStack', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'StackName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TemplateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), 'TemplateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'StackPolicyDuringUpdateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'StackPolicyDuringUpdateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1350, ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), 'Capabilities' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Capabilities.member', 'items' => array( 'name' => 'Capability', 'type' => 'string', ), ), 'StackPolicyBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'StackPolicyURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1350, ), ), 'errorResponses' => array( array( 'reason' => 'The template contains resources with capabilities that were not specified in the Capabilities parameter.', 'class' => 'InsufficientCapabilitiesException', ), ), ), 'ValidateTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ValidateTemplateOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ValidateTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-15', ), 'TemplateBody' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), 'TemplateURL' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreateStackOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeStackEventsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackEvents' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StackEvent', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'EventId' => array( 'type' => 'string', ), 'StackName' => array( 'type' => 'string', ), 'LogicalResourceId' => array( 'type' => 'string', ), 'PhysicalResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Timestamp' => array( 'type' => 'string', ), 'ResourceStatus' => array( 'type' => 'string', ), 'ResourceStatusReason' => array( 'type' => 'string', ), 'ResourceProperties' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeStackResourceOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackResourceDetail' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'StackName' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'LogicalResourceId' => array( 'type' => 'string', ), 'PhysicalResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'LastUpdatedTimestamp' => array( 'type' => 'string', ), 'ResourceStatus' => array( 'type' => 'string', ), 'ResourceStatusReason' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Metadata' => array( 'type' => 'string', ), ), ), ), ), 'DescribeStackResourcesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackResources' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StackResource', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'StackName' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'LogicalResourceId' => array( 'type' => 'string', ), 'PhysicalResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'Timestamp' => array( 'type' => 'string', ), 'ResourceStatus' => array( 'type' => 'string', ), 'ResourceStatusReason' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeStacksOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stacks' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Stack', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'StackName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Parameters' => array( 'type' => 'array', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), 'CreationTime' => array( 'type' => 'string', ), 'LastUpdatedTime' => array( 'type' => 'string', ), 'StackStatus' => array( 'type' => 'string', ), 'StackStatusReason' => array( 'type' => 'string', ), 'DisableRollback' => array( 'type' => 'boolean', ), 'NotificationARNs' => array( 'type' => 'array', 'items' => array( 'name' => 'NotificationARN', 'type' => 'string', 'sentAs' => 'member', ), ), 'TimeoutInMinutes' => array( 'type' => 'numeric', ), 'Capabilities' => array( 'type' => 'array', 'items' => array( 'name' => 'Capability', 'type' => 'string', 'sentAs' => 'member', ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'Output', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'OutputKey' => array( 'type' => 'string', ), 'OutputValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), 'Tags' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'EstimateTemplateCostOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Url' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetStackPolicyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackPolicyBody' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetTemplateOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TemplateBody' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListStackResourcesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackResourceSummaries' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StackResourceSummary', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'LogicalResourceId' => array( 'type' => 'string', ), 'PhysicalResourceId' => array( 'type' => 'string', ), 'ResourceType' => array( 'type' => 'string', ), 'LastUpdatedTimestamp' => array( 'type' => 'string', ), 'ResourceStatus' => array( 'type' => 'string', ), 'ResourceStatusReason' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListStacksOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackSummaries' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StackSummary', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'StackName' => array( 'type' => 'string', ), 'TemplateDescription' => array( 'type' => 'string', ), 'CreationTime' => array( 'type' => 'string', ), 'LastUpdatedTime' => array( 'type' => 'string', ), 'DeletionTime' => array( 'type' => 'string', ), 'StackStatus' => array( 'type' => 'string', ), 'StackStatusReason' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'UpdateStackOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ValidateTemplateOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Parameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'TemplateParameter', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ParameterKey' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'NoEcho' => array( 'type' => 'boolean', ), 'Description' => array( 'type' => 'string', ), ), ), ), 'Description' => array( 'type' => 'string', 'location' => 'xml', ), 'Capabilities' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Capability', 'type' => 'string', 'sentAs' => 'member', ), ), 'CapabilitiesReason' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeStackEvents' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'StackEvents', ), 'DescribeStacks' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Stacks', ), 'ListStackResources' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'StackResourceSummaries', ), 'ListStacks' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'StackSummaries', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudfront-%s.php', )) ->setExceptionParser(new DefaultXmlExceptionParser()) ->setIteratorsConfig(array( 'token_param' => 'Marker', 'token_key' => 'NextMarker', 'more_key' => 'IsTruncated', 'result_key' => 'Items', 'operations' => array( 'ListCloudFrontOriginAccessIdentities', 'ListDistributions', 'ListInvalidations', 'ListStreamingDistributions' ) )) ->build(); } /** * Create a signed URL. Keep in mind that URLs meant for use in media/flash players may have different requirements * for URL formats (e.g. some require that the extension be removed, some require the file name to be prefixed - * mp4:, some require you to add "/cfx/st" into your URL). See * http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/WorkingWithStreamingDistributions.html for * additional details and help. * * This method accepts an array of configuration options: * - url: (string) URL of the resource being signed (can include query string and wildcards). For example: * rtmp://s5c39gqb8ow64r.cloudfront.net/videos/mp3_name.mp3 * http://d111111abcdef8.cloudfront.net/images/horizon.jpg?size=large&license=yes * - policy: (string) JSON policy. Use this option when creating a signed URL for a custom policy. * - expires: (int) UTC Unix timestamp used when signing with a canned policy. Not required when passing a * custom 'policy' option. * - key_pair_id: (string) The ID of the key pair used to sign CloudFront URLs for private distributions. * - private_key: (string) The filepath ot the private key used to sign CloudFront URLs for private distributions. * * @param array $options Array of configuration options used when signing * * @return string The file URL with authentication parameters * @throws InvalidArgumentException if key_pair_id and private_key have not been configured on the client * @throws RequiredExtensionNotLoadedException if the openssl extension is not installed * @link http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/WorkingWithStreamingDistributions.html */ public function getSignedUrl(array $options) { if (!extension_loaded('openssl')) { //@codeCoverageIgnoreStart throw new RequiredExtensionNotLoadedException('The openssl extension is required to sign CloudFront urls.'); //@codeCoverageIgnoreEnd } // Initialize the configuration data and ensure that the url was specified $options = Collection::fromConfig($options, array_filter(array( 'key_pair_id' => $this->getConfig('key_pair_id'), 'private_key' => $this->getConfig('private_key'), )), array('url', 'key_pair_id', 'private_key')); // Determine the scheme of the url $urlSections = explode('://', $options['url']); if (count($urlSections) < 2) { throw new InvalidArgumentException('Invalid URL: ' . $options['url']); } // Get the real scheme by removing wildcards from the scheme $scheme = str_replace('*', '', $urlSections[0]); $policy = $options['policy'] ?: $this->createCannedPolicy($scheme, $options['url'], $options['expires']); // Strip whitespace from the policy $policy = str_replace(' ', '', $policy); $url = Url::factory($scheme . '://' . $urlSections[1]); if ($options['policy']) { // Custom policies require that the encoded policy be specified in the URL $url->getQuery()->set('Policy', strtr(base64_encode($policy), '+=/', '-_~')); } else { // Canned policies require that the Expires parameter be set in the URL $url->getQuery()->set('Expires', $options['expires']); } // Sign the policy using the CloudFront private key $signedPolicy = $this->rsaSha1Sign($policy, $options['private_key']); // Remove whitespace, base64 encode the policy, and replace special characters $signedPolicy = strtr(base64_encode($signedPolicy), '+=/', '-_~'); $url->getQuery() ->set('Signature', $signedPolicy) ->set('Key-Pair-Id', $options['key_pair_id']); if ($scheme != 'rtmp') { // HTTP and HTTPS signed URLs include the full URL return (string) $url; } else { // Use a relative URL when creating Flash player URLs $url->getQuery()->useUrlEncoding(false); $url->setScheme(null)->setHost(null); return substr($url, 1); } } /** * Sign a policy string using OpenSSL RSA SHA1 * * @param string $policy Policy to sign * @param string $privateKeyFilename File containing the OpenSSL private key * * @return string */ protected function rsaSha1Sign($policy, $privateKeyFilename) { $signature = ''; openssl_sign($policy, $signature, file_get_contents($privateKeyFilename)); return $signature; } /** * Create a canned policy for a particular URL and expiration * * @param string $scheme Parsed scheme without wildcards * @param string $url URL that is being signed * @param int $expires Time in which the signature expires * * @return string * @throws InvalidArgumentException if the expiration is not set */ protected function createCannedPolicy($scheme, $url, $expires) { if (!$expires) { throw new InvalidArgumentException('An expires option is required when using a canned policy'); } // Generate a canned policy if ($scheme == 'http' || $scheme == 'https') { $resource = $url; } elseif ($scheme == 'rtmp') { $parts = parse_url($url); $pathParts = pathinfo($parts['path']); // Add path leading to file, strip file extension, and add a query string if present $resource = ltrim($pathParts['dirname'] . '/' . $pathParts['basename'], '/') . (isset($parts['query']) ? "?{$parts['query']}" : ''); } else { throw new InvalidArgumentException("Invalid URI scheme: {$scheme}. Must be one of http or rtmp."); } return sprintf( '{"Statement":[{"Resource":"%s","Condition":{"DateLessThan":{"AWS:EpochTime":%d}}}]}', $resource, $expires ); } } hasHeader('date') && !$request->hasHeader('x-amz-date')) { $request->setHeader('Date', gmdate(DateFormat::RFC2822)); } $stringToSign = (string) $request->getHeader('Date') ?: (string) $request->getHeader('x-amz-date'); $request->getParams()->set('aws.string_to_sign', $stringToSign); $request->setHeader( 'Authorization', 'AWS ' . $credentials->getAccessKeyId() . ':' . $this->signString($stringToSign, $credentials) ); } /** * Sign a signature string by applying SHA-1 HMAC hashing. * * @param string $string The signature string to hash. * @param CredentialsInterface $credentials Signing credentials. * * @return string The hashed signature string. */ public function signString($string, CredentialsInterface $credentials) { return base64_encode(hash_hmac('sha1', $string, $credentials->getSecretKey(), true)); } } '2012-05-05', 'endpointPrefix' => 'cloudfront', 'serviceFullName' => 'Amazon CloudFront', 'serviceAbbreviation' => 'CloudFront', 'serviceType' => 'rest-xml', 'globalEndpoint' => 'cloudfront.amazonaws.com', 'signatureVersion' => 'cloudfront', 'namespace' => 'CloudFront', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), ), 'operations' => array( 'CreateCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/2012-05-05/origin-access-identity/cloudfront', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'summary' => 'Create a new origin access identity.', 'data' => array( 'xmlRoot' => array( 'name' => 'CloudFrontOriginAccessIdentityConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CloudFrontOriginAccessIdentityAlreadyExistsException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'TooManyCloudFrontOriginAccessIdentitiesException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateDistribution' => array( 'httpMethod' => 'POST', 'uri' => '/2012-05-05/distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateDistributionResult', 'responseType' => 'model', 'summary' => 'Create a new distribution.', 'data' => array( 'xmlRoot' => array( 'name' => 'DistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'required' => true, 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'DefaultRootObject' => array( 'required' => true, 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'required' => true, 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'required' => true, 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'required' => true, 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'required' => true, 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'required' => true, 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'required' => true, 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', 'enum' => array( 'http-only', 'match-viewer', ), ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'required' => true, 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'required' => true, 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', 'enum' => array( 'allow-all', 'https-only', ), ), 'MinTTL' => array( 'required' => true, 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'required' => true, 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'PathPattern' => array( 'required' => true, 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'required' => true, 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', 'enum' => array( 'allow-all', 'https-only', ), ), 'MinTTL' => array( 'required' => true, 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'required' => true, 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'DistributionAlreadyExistsException', ), array( 'class' => 'InvalidOriginException', ), array( 'class' => 'InvalidOriginAccessIdentityException', ), array( 'class' => 'AccessDeniedException', ), array( 'class' => 'TooManyTrustedSignersException', ), array( 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'TooManyDistributionCNAMEsException', ), array( 'class' => 'TooManyDistributionsException', ), array( 'class' => 'InvalidDefaultRootObjectException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InvalidRequiredProtocolException', ), array( 'class' => 'NoSuchOriginException', ), array( 'class' => 'TooManyOriginsException', ), array( 'class' => 'TooManyCacheBehaviorsException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateInvalidation' => array( 'httpMethod' => 'POST', 'uri' => '/2012-05-05/distribution/{DistributionId}/invalidation', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateInvalidationResult', 'responseType' => 'model', 'summary' => 'Create a new invalidation.', 'data' => array( 'xmlRoot' => array( 'name' => 'InvalidationBatch', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'DistributionId' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'Paths' => array( 'required' => true, 'description' => 'The path of the object to invalidate. The path is relative to the distribution and must begin with a slash (/). You must enclose each invalidation object with the Path element tags. If the path includes non-ASCII characters or unsafe characters as defined in RFC 1783 (http://www.ietf.org/rfc/rfc1738.txt), URL encode those characters. Do not URL encode any other characters in the path, or CloudFront will not invalidate the old version of the updated object.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of objects that you want to invalidate.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains a list of the objects that you want to invalidate.', 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', ), ), ), ), 'CallerReference' => array( 'required' => true, 'description' => 'A unique name that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the Path object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create an invalidation batch, and the content of each Path element is identical to the original request, the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of any Path is different from the original request, CloudFront returns an InvalidationBatchAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'BatchTooLargeException', ), array( 'class' => 'TooManyInvalidationsInProgressException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateStreamingDistribution' => array( 'httpMethod' => 'POST', 'uri' => '/2012-05-05/streaming-distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateStreamingDistributionResult', 'responseType' => 'model', 'summary' => 'Create a new streaming distribution.', 'data' => array( 'xmlRoot' => array( 'name' => 'StreamingDistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'required' => true, 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'required' => true, 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'required' => true, 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'required' => true, 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'Enabled' => array( 'required' => true, 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'StreamingDistributionAlreadyExistsException', ), array( 'class' => 'InvalidOriginException', ), array( 'class' => 'InvalidOriginAccessIdentityException', ), array( 'class' => 'AccessDeniedException', ), array( 'class' => 'TooManyTrustedSignersException', ), array( 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'TooManyStreamingDistributionCNAMEsException', ), array( 'class' => 'TooManyStreamingDistributionsException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'DeleteCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-05-05/origin-access-identity/cloudfront/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteCloudFrontOriginAccessIdentity2012_05_05Output', 'responseType' => 'model', 'summary' => 'Delete an origin access identity.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The origin access identity\'s id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received from a previous GET or PUT request. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'class' => 'PreconditionFailedException', ), array( 'class' => 'CloudFrontOriginAccessIdentityInUseException', ), ), ), 'DeleteDistribution' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-05-05/distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteDistribution2012_05_05Output', 'responseType' => 'model', 'summary' => 'Delete a distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The distribution id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when you disabled the distribution. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'DistributionNotDisabledException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'PreconditionFailedException', ), ), ), 'DeleteStreamingDistribution' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-05-05/streaming-distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteStreamingDistribution2012_05_05Output', 'responseType' => 'model', 'summary' => 'Delete a streaming distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The distribution id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when you disabled the streaming distribution. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'StreamingDistributionNotDisabledException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'NoSuchStreamingDistributionException', ), array( 'class' => 'PreconditionFailedException', ), ), ), 'GetCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/origin-access-identity/cloudfront/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'summary' => 'Get the information about an origin access identity.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The identity\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetCloudFrontOriginAccessIdentityConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/origin-access-identity/cloudfront/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetCloudFrontOriginAccessIdentityConfigResult', 'responseType' => 'model', 'summary' => 'Get the configuration information about an origin access identity.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The identity\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetDistribution' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetDistributionResult', 'responseType' => 'model', 'summary' => 'Get the information about a distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetDistributionConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetDistributionConfigResult', 'responseType' => 'model', 'summary' => 'Get the configuration information about a distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetInvalidation' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution/{DistributionId}/invalidation/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetInvalidationResult', 'responseType' => 'model', 'summary' => 'Get the information about an invalidation.', 'parameters' => array( 'DistributionId' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'Id' => array( 'required' => true, 'description' => 'The invalidation\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchInvalidationException', ), array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetStreamingDistribution' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/streaming-distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetStreamingDistributionResult', 'responseType' => 'model', 'summary' => 'Get the information about a streaming distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The streaming distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchStreamingDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'GetStreamingDistributionConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/streaming-distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetStreamingDistributionConfigResult', 'responseType' => 'model', 'summary' => 'Get the configuration information about a streaming distribution.', 'parameters' => array( 'Id' => array( 'required' => true, 'description' => 'The streaming distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchStreamingDistributionException', ), array( 'class' => 'AccessDeniedException', ), ), ), 'ListCloudFrontOriginAccessIdentities' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/origin-access-identity/cloudfront', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListCloudFrontOriginAccessIdentitiesResult', 'responseType' => 'model', 'summary' => 'List origin access identities.', 'parameters' => array( 'Marker' => array( 'description' => 'Use this when paginating results to indicate where to begin in your list of origin access identities. The results include identities in the list that occur after the marker. To get the next page of results, set the Marker to the value of the NextMarker from the current page\'s response (which is also the ID of the last identity on that page).', 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'description' => 'The maximum number of origin access identities you want in the response body.', 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'InvalidArgumentException', ), ), ), 'ListDistributions' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListDistributionsResult', 'responseType' => 'model', 'summary' => 'List distributions.', 'parameters' => array( 'Marker' => array( 'description' => 'Use this when paginating results to indicate where to begin in your list of distributions. The results include distributions in the list that occur after the marker. To get the next page of results, set the Marker to the value of the NextMarker from the current page\'s response (which is also the ID of the last distribution on that page).', 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'description' => 'The maximum number of distributions you want in the response body.', 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'InvalidArgumentException', ), ), ), 'ListInvalidations' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/distribution/{DistributionId}/invalidation', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListInvalidationsResult', 'responseType' => 'model', 'summary' => 'List invalidation batches.', 'parameters' => array( 'DistributionId' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'Marker' => array( 'description' => 'Use this parameter when paginating results to indicate where to begin in your list of invalidation batches. Because the results are returned in decreasing order from most recent to oldest, the most recent results are on the first page, the second page will contain earlier results, and so on. To get the next page of results, set the Marker to the value of the NextMarker from the current page\'s response. This value is the same as the ID of the last invalidation batch on that page.', 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'description' => 'The maximum number of invalidation batches you want in the response body.', 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'NoSuchDistributionException', ), ), ), 'ListStreamingDistributions' => array( 'httpMethod' => 'GET', 'uri' => '/2012-05-05/streaming-distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListStreamingDistributionsResult', 'responseType' => 'model', 'summary' => 'List streaming distributions.', 'parameters' => array( 'Marker' => array( 'description' => 'Use this when paginating results to indicate where to begin in your list of streaming distributions. The results include distributions in the list that occur after the marker. To get the next page of results, set the Marker to the value of the NextMarker from the current page\'s response (which is also the ID of the last distribution on that page).', 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'description' => 'The maximum number of streaming distributions you want in the response body.', 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'InvalidArgumentException', ), ), ), 'UpdateCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'PUT', 'uri' => '/2012-05-05/origin-access-identity/cloudfront/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'summary' => 'Update an origin access identity.', 'data' => array( 'xmlRoot' => array( 'name' => 'CloudFrontOriginAccessIdentityConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'description' => 'The identity\'s id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when retrieving the identity\'s configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'IllegalUpdateException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'class' => 'PreconditionFailedException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'UpdateDistribution' => array( 'httpMethod' => 'PUT', 'uri' => '/2012-05-05/distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateDistributionResult', 'responseType' => 'model', 'summary' => 'Update a distribution.', 'data' => array( 'xmlRoot' => array( 'name' => 'DistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'required' => true, 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'DefaultRootObject' => array( 'required' => true, 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'required' => true, 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'required' => true, 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'required' => true, 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'required' => true, 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'required' => true, 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'required' => true, 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', 'enum' => array( 'http-only', 'match-viewer', ), ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'required' => true, 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'required' => true, 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', 'enum' => array( 'allow-all', 'https-only', ), ), 'MinTTL' => array( 'required' => true, 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'required' => true, 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'PathPattern' => array( 'required' => true, 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'required' => true, 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', 'enum' => array( 'allow-all', 'https-only', ), ), 'MinTTL' => array( 'required' => true, 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'required' => true, 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'description' => 'The distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when retrieving the distribution\'s configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'IllegalUpdateException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'NoSuchDistributionException', ), array( 'class' => 'PreconditionFailedException', ), array( 'class' => 'TooManyDistributionCNAMEsException', ), array( 'class' => 'InvalidDefaultRootObjectException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InvalidOriginAccessIdentityException', ), array( 'class' => 'TooManyTrustedSignersException', ), array( 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'InvalidRequiredProtocolException', ), array( 'class' => 'NoSuchOriginException', ), array( 'class' => 'TooManyOriginsException', ), array( 'class' => 'TooManyCacheBehaviorsException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), 'UpdateStreamingDistribution' => array( 'httpMethod' => 'PUT', 'uri' => '/2012-05-05/streaming-distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateStreamingDistributionResult', 'responseType' => 'model', 'summary' => 'Update a streaming distribution.', 'data' => array( 'xmlRoot' => array( 'name' => 'StreamingDistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2012-05-05/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'required' => true, 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'required' => true, 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'required' => true, 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'required' => true, 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'Comment' => array( 'required' => true, 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'Enabled' => array( 'required' => true, 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'description' => 'The streaming distribution\'s id.', 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'description' => 'The value of the ETag header you received when retrieving the streaming distribution\'s configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'AccessDeniedException', ), array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'IllegalUpdateException', ), array( 'class' => 'InvalidIfMatchVersionException', ), array( 'class' => 'MissingBodyException', ), array( 'class' => 'NoSuchStreamingDistributionException', ), array( 'class' => 'PreconditionFailedException', ), array( 'class' => 'TooManyStreamingDistributionCNAMEsException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'InvalidOriginAccessIdentityException', ), array( 'class' => 'TooManyTrustedSignersException', ), array( 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'InconsistentQuantitiesException', ), ), ), ), 'models' => array( 'CreateCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The ID for the origin access identity. For example: E74FTE3AJFJ256A.', 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'description' => 'The Amazon S3 canonical user ID for the origin access identity, which you use when giving the origin access identity read permission to an object in Amazon S3.', 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'description' => 'The current configuration information for the identity.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', ), 'Comment' => array( 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', ), ), ), 'Location' => array( 'description' => 'The fully qualified URI of the new origin access identity just created. For example: https://cloudfront.amazonaws.com/2010-11-01/origin-access-identity/cloudfront/E74FTE3AJFJ256A.', 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'description' => 'The current version of the origin access identity created.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'This response element indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'description' => 'The number of invalidation batches currently in progress.', 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'description' => 'The current configuration information for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'Location' => array( 'description' => 'The fully qualified URI of the new distribution resource just created. For example: https://cloudfront.amazonaws.com/2010-11-01/distribution/EDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'description' => 'The current version of the distribution created.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateInvalidationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Location' => array( 'description' => 'The fully qualified URI of the distribution and invalidation batch request, including the Invalidation ID.', 'type' => 'string', 'location' => 'header', ), 'Id' => array( 'description' => 'The identifier for the invalidation request. For example: IDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The status of the invalidation request. When the invalidation batch is finished, the status is Completed.', 'type' => 'string', 'location' => 'xml', ), 'CreateTime' => array( 'description' => 'The date and time the invalidation request was first made.', 'type' => 'string', 'location' => 'xml', ), 'InvalidationBatch' => array( 'description' => 'The current invalidation information for the batch request.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Paths' => array( 'description' => 'The path of the object to invalidate. The path is relative to the distribution and must begin with a slash (/). You must enclose each invalidation object with the Path element tags. If the path includes non-ASCII characters or unsafe characters as defined in RFC 1783 (http://www.ietf.org/rfc/rfc1738.txt), URL encode those characters. Do not URL encode any other characters in the path, or CloudFront will not invalidate the old version of the updated object.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of objects that you want to invalidate.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains a list of the objects that you want to invalidate.', 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', 'sentAs' => 'Path', ), ), ), ), 'CallerReference' => array( 'description' => 'A unique name that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the Path object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create an invalidation batch, and the content of each Path element is identical to the original request, the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of any Path is different from the original request, CloudFront returns an InvalidationBatchAlreadyExists error.', 'type' => 'string', ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the streaming distribution. For example: EGTXBD79H29TRA8.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The current status of the streaming distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the streaming distribution. For example: s5c39gqb8ow64r.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'description' => 'The current configuration information for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Enabled' => array( 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'Location' => array( 'description' => 'The fully qualified URI of the new streaming distribution resource just created. For example: https://cloudfront.amazonaws.com/2010-11-01/streaming-distribution/EGTXBD79H29TRA8.', 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'description' => 'The current version of the streaming distribution created.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteCloudFrontOriginAccessIdentity2012_05_05Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteDistribution2012_05_05Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteStreamingDistribution2012_05_05Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The ID for the origin access identity. For example: E74FTE3AJFJ256A.', 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'description' => 'The Amazon S3 canonical user ID for the origin access identity, which you use when giving the origin access identity read permission to an object in Amazon S3.', 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'description' => 'The current configuration information for the identity.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', ), 'Comment' => array( 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', ), ), ), 'ETag' => array( 'description' => 'The current version of the origin access identity\'s information. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetCloudFrontOriginAccessIdentityConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', 'location' => 'xml', ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'This response element indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'description' => 'The number of invalidation batches currently in progress.', 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'description' => 'The current configuration information for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'ETag' => array( 'description' => 'The current version of the distribution\'s information. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetDistributionConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'location' => 'xml', ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetInvalidationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the invalidation request. For example: IDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The status of the invalidation request. When the invalidation batch is finished, the status is Completed.', 'type' => 'string', 'location' => 'xml', ), 'CreateTime' => array( 'description' => 'The date and time the invalidation request was first made.', 'type' => 'string', 'location' => 'xml', ), 'InvalidationBatch' => array( 'description' => 'The current invalidation information for the batch request.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Paths' => array( 'description' => 'The path of the object to invalidate. The path is relative to the distribution and must begin with a slash (/). You must enclose each invalidation object with the Path element tags. If the path includes non-ASCII characters or unsafe characters as defined in RFC 1783 (http://www.ietf.org/rfc/rfc1738.txt), URL encode those characters. Do not URL encode any other characters in the path, or CloudFront will not invalidate the old version of the updated object.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of objects that you want to invalidate.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains a list of the objects that you want to invalidate.', 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', 'sentAs' => 'Path', ), ), ), ), 'CallerReference' => array( 'description' => 'A unique name that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the Path object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create an invalidation batch, and the content of each Path element is identical to the original request, the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of any Path is different from the original request, CloudFront returns an InvalidationBatchAlreadyExists error.', 'type' => 'string', ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the streaming distribution. For example: EGTXBD79H29TRA8.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The current status of the streaming distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the streaming distribution. For example: s5c39gqb8ow64r.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'description' => 'The current configuration information for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Enabled' => array( 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'ETag' => array( 'description' => 'The current version of the streaming distribution\'s information. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetStreamingDistributionConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Enabled' => array( 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', 'location' => 'xml', ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListCloudFrontOriginAccessIdentitiesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'description' => 'The value you provided for the Marker request parameter.', 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'description' => 'If IsTruncated is true, this element is present and contains the value you can use for the Marker request parameter to continue listing your origin access identities where they left off.', 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'description' => 'The value you provided for the MaxItems request parameter.', 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'description' => 'A flag that indicates whether more origin access identities remain to be listed. If your results were truncated, you can make a follow-up pagination request using the Marker request parameter to retrieve more items in the list.', 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'description' => 'The number of CloudFront origin access identities that were created by the current AWS account.', 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'description' => 'A complex type that contains one CloudFrontOriginAccessIdentitySummary element for each origin access identity that was created by the current AWS account.', 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CloudFrontOriginAccessIdentitySummary', 'description' => 'Summary of the information about a CloudFront origin access identity.', 'type' => 'object', 'sentAs' => 'CloudFrontOriginAccessIdentitySummary', 'properties' => array( 'Id' => array( 'description' => 'The ID for the origin access identity. For example: E74FTE3AJFJ256A.', 'type' => 'string', ), 'S3CanonicalUserId' => array( 'description' => 'The Amazon S3 canonical user ID for the origin access identity, which you use when giving the origin access identity read permission to an object in Amazon S3.', 'type' => 'string', ), 'Comment' => array( 'description' => 'The comment for this origin access identity, as originally specified when created.', 'type' => 'string', ), ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListDistributionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'description' => 'The value you provided for the Marker request parameter.', 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'description' => 'If IsTruncated is true, this element is present and contains the value you can use for the Marker request parameter to continue listing your distributions where they left off.', 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'description' => 'The value you provided for the MaxItems request parameter.', 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'description' => 'A flag that indicates whether more distributions remain to be listed. If your results were truncated, you can make a follow-up pagination request using the Marker request parameter to retrieve more distributions in the list.', 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'description' => 'The number of distributions that were created by the current AWS account.', 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'description' => 'A complex type that contains one DistributionSummary element for each distribution that was created by the current AWS account.', 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DistributionSummary', 'description' => 'A summary of the information for an Amazon CloudFront distribution.', 'type' => 'object', 'sentAs' => 'DistributionSummary', 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', ), 'Status' => array( 'description' => 'This response element indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'The comment originally specified when this distribution was created.', 'type' => 'string', ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListInvalidationsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'description' => 'The value you provided for the Marker request parameter.', 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'description' => 'If IsTruncated is true, this element is present and contains the value you can use for the Marker request parameter to continue listing your invalidation batches where they left off.', 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'description' => 'The value you provided for the MaxItems request parameter.', 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'description' => 'A flag that indicates whether more invalidation batch requests remain to be listed. If your results were truncated, you can make a follow-up pagination request using the Marker request parameter to retrieve more invalidation batches in the list.', 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'description' => 'The number of invalidation batches that were created by the current AWS account.', 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'description' => 'A complex type that contains one InvalidationSummary element for each invalidation batch that was created by the current AWS account.', 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InvalidationSummary', 'description' => 'Summary of an invalidation request.', 'type' => 'object', 'sentAs' => 'InvalidationSummary', 'properties' => array( 'Id' => array( 'description' => 'The unique ID for an invalidation request.', 'type' => 'string', ), 'Status' => array( 'description' => 'The status of an invalidation request.', 'type' => 'string', ), ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListStreamingDistributionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'description' => 'The value you provided for the Marker request parameter.', 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'description' => 'If IsTruncated is true, this element is present and contains the value you can use for the Marker request parameter to continue listing your streaming distributions where they left off.', 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'description' => 'The value you provided for the MaxItems request parameter.', 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'description' => 'A flag that indicates whether more streaming distributions remain to be listed. If your results were truncated, you can make a follow-up pagination request using the Marker request parameter to retrieve more distributions in the list.', 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'description' => 'The number of streaming distributions that were created by the current AWS account.', 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'description' => 'A complex type that contains one StreamingDistributionSummary element for each distribution that was created by the current AWS account.', 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StreamingDistributionSummary', 'description' => 'A summary of the information for an Amazon CloudFront streaming distribution.', 'type' => 'object', 'sentAs' => 'StreamingDistributionSummary', 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', ), 'Status' => array( 'description' => 'Indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Comment' => array( 'description' => 'The comment originally specified when this distribution was created.', 'type' => 'string', ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The ID for the origin access identity. For example: E74FTE3AJFJ256A.', 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'description' => 'The Amazon S3 canonical user ID for the origin access identity, which you use when giving the origin access identity read permission to an object in Amazon S3.', 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'description' => 'The current configuration information for the identity.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the CloudFrontOriginAccessIdentityConfig object), a new origin access identity is created. If the CallerReference is a value you already sent in a previous request to create an identity, and the content of the CloudFrontOriginAccessIdentityConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'type' => 'string', ), 'Comment' => array( 'description' => 'Any comments you want to include about the origin access identity.', 'type' => 'string', ), ), ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the distribution. For example: EDFDVBD632BHDS5.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'This response element indicates the current status of the distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'description' => 'The number of invalidation batches currently in progress.', 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the distribution. For example: d604721fxaaqy9.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'description' => 'The current configuration information for the distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the DistributionConfig object), a new distribution is created. If the CallerReference is a value you already sent in a previous request to create a distribution, and the content of the DistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a distribution but the content of the DistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'description' => 'The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL for your distribution (http://www.example.com) instead of an object in your distribution (http://www.example.com/index.html). Specifying a default root object avoids exposing the contents of your distribution. If you don\'t want to specify a default root object when you create a distribution, include an empty DefaultRootObject element. To delete the default root object from an existing distribution, update the distribution configuration and include an empty DefaultRootObject element. To replace the default root object, update the distribution configuration and specify the new object.', 'type' => 'string', ), 'Origins' => array( 'description' => 'A complex type that contains information about origins for this distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of origins for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains origins for this distribution.', 'type' => 'array', 'items' => array( 'name' => 'Origin', 'description' => 'A complex type that describes the Amazon S3 bucket or the HTTP server (for example, a web server) from which CloudFront gets your files.You must create at least one origin.', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'description' => 'A unique identifier for the origin. The value of Id must be unique within the distribution. You use the value of Id when you create a cache behavior. The Id identifies the origin that CloudFront routes a request to when the request matches the path pattern for that cache behavior.', 'type' => 'string', ), 'DomainName' => array( 'description' => 'Amazon S3 origins: The DNS name of the Amazon S3 bucket from which you want CloudFront to get objects for this origin, for example, myawsbucket.s3.amazonaws.com. Custom origins: The DNS domain name for the HTTP server from which you want CloudFront to get objects for this origin, for example, www.example.com.', 'type' => 'string', ), 'S3OriginConfig' => array( 'description' => 'A complex type that contains information about the Amazon S3 origin. If the origin is a custom origin, use the CustomOriginConfig element instead.', 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'description' => 'The CloudFront origin access identity to associate with the origin. Use an origin access identity to configure the origin so that end users can only access objects in an Amazon S3 bucket through CloudFront. If you want end users to be able to access objects using either the CloudFront URL or the Amazon S3 URL, specify an empty OriginAccessIdentity element. To delete the origin access identity from an existing distribution, update the distribution configuration and include an empty OriginAccessIdentity element. To replace the origin access identity, update the distribution configuration and specify the new origin access identity.', 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'description' => 'A complex type that contains information about a custom origin. If the origin is an Amazon S3 bucket, use the S3OriginConfig element instead.', 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'description' => 'The HTTP port the custom origin listens on.', 'type' => 'numeric', ), 'HTTPSPort' => array( 'description' => 'The HTTPS port the custom origin listens on.', 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'description' => 'The origin protocol policy to apply to your origin.', 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'description' => 'A complex type that describes the default cache behavior if you do not specify a CacheBehavior element or if files don\'t match any of the values of PathPattern in CacheBehavior elements.You must create exactly one default cache behavior.', 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), 'CacheBehaviors' => array( 'description' => 'A complex type that contains zero or more CacheBehavior elements.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of cache behaviors for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains cache behaviors for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'description' => 'A complex type that describes how CloudFront processes requests. You can create up to 10 cache behaviors.You must create at least as many cache behaviors (including the default cache behavior) as you have origins if you want CloudFront to distribute objects from all of the origins. Each cache behavior specifies the one origin from which you want CloudFront to get objects. If you have two origins and only the default cache behavior, the default cache behavior will cause CloudFront to get objects from one of the origins, but the other origin will never be used. If you don\'t want to specify any cache behaviors, include only an empty CacheBehaviors element. Don\'t include an empty CacheBehavior element, or CloudFront returns a MalformedXML error. To delete all cache behaviors in an existing distribution, update the distribution configuration and include only an empty CacheBehaviors element. To add, change, or remove one or more cache behaviors, update the distribution configuration and specify all of the cache behaviors that you want to include in the updated distribution.', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'description' => 'The pattern (for example, images/*.jpg) that specifies which requests you want this cache behavior to apply to. When CloudFront receives an end-user request, the requested path is compared with path patterns in the order in which cache behaviors are listed in the distribution. The path pattern for the default cache behavior is * and cannot be changed. If the request for an object does not match the path pattern for any cache behaviors, CloudFront applies the behavior in the default cache behavior.', 'type' => 'string', ), 'TargetOriginId' => array( 'description' => 'The value of ID for the origin that you want CloudFront to route requests to when a request matches the path pattern either for a cache behavior or for the default cache behavior.', 'type' => 'string', ), 'ForwardedValues' => array( 'description' => 'A complex type that specifies how CloudFront handles query strings.', 'type' => 'object', 'properties' => array( 'QueryString' => array( 'description' => 'Indicates whether you want CloudFront to forward query strings to the origin that is associated with this cache behavior. If so, specify true; if not, specify false.', 'type' => 'boolean', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'description' => 'Use this element to specify the protocol that users can use to access the files in the origin specified by TargetOriginId when a request matches the path pattern in PathPattern. If you want CloudFront to allow end users to use any available protocol, specify allow-all. If you want CloudFront to require HTTPS, specify https.', 'type' => 'string', ), 'MinTTL' => array( 'description' => 'The minimum amount of time that you want objects to stay in CloudFront caches before CloudFront queries your origin to see whether the object has been updated.You can specify a value from 0 to 3,153,600,000 seconds (100 years).', 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'Enabled' => array( 'description' => 'Whether the distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'description' => 'The identifier for the streaming distribution. For example: EGTXBD79H29TRA8.', 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'description' => 'The current status of the streaming distribution. When the status is Deployed, the distribution\'s information is fully propagated throughout the Amazon CloudFront system.', 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'description' => 'The date and time the distribution was last modified.', 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'description' => 'The domain name corresponding to the streaming distribution. For example: s5c39gqb8ow64r.cloudfront.net.', 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'description' => 'CloudFront automatically adds this element to the response only if you\'ve set up the distribution to serve private content with signed URLs. The element lists the key pair IDs that CloudFront is aware of for each trusted signer. The Signer child element lists the AWS account number of the trusted signer (or an empty Self element if the signer is you). The Signer element also includes the IDs of any active key pairs associated with the trusted signer\'s AWS account. If no KeyPairId element appears for a Signer, that signer can\'t create working signed URLs.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'description' => 'Each active trusted signer.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of unique trusted signers included in all cache behaviors. For example, if three cache behaviors all list the same three AWS accounts, the value of Quantity for ActiveTrustedSigners will be 3.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that contains one Signer complex type for each unique trusted signer that is specified in the TrustedSigners complex type, including trusted signers in the default cache behavior and in all of the other cache behaviors.', 'type' => 'array', 'items' => array( 'name' => 'Signer', 'description' => 'A complex type that lists the AWS accounts that were included in the TrustedSigners complex type, as well as their active CloudFront key pair IDs, if any.', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'description' => 'Specifies an AWS account that can create signed URLs. Values: self, which indicates that the AWS account that was used to create the distribution can created signed URLs, or an AWS account number. Omit the dashes in the account number.', 'type' => 'string', ), 'KeyPairIds' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of active CloudFront key pairs for AwsAccountNumber.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'A complex type that lists the active CloudFront key pairs, if any, that are associated with AwsAccountNumber.', 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'description' => 'The current configuration information for the streaming distribution.', 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'description' => 'A unique number that ensures the request can\'t be replayed. If the CallerReference is new (no matter the content of the StreamingDistributionConfig object), a new streaming distribution is created. If the CallerReference is a value you already sent in a previous request to create a streaming distribution, and the content of the StreamingDistributionConfig is identical to the original request (ignoring white space), the response includes the same information returned to the original request. If the CallerReference is a value you already sent in a previous request to create a streaming distribution but the content of the StreamingDistributionConfig is different from the original request, CloudFront returns a DistributionAlreadyExists error.', 'type' => 'string', ), 'S3Origin' => array( 'description' => 'A complex type that contains information about the Amazon S3 bucket from which you want CloudFront to get your media files for distribution.', 'type' => 'object', 'properties' => array( 'DomainName' => array( 'description' => 'The DNS name of the S3 origin.', 'type' => 'string', ), 'OriginAccessIdentity' => array( 'description' => 'Your S3 origin\'s origin access identity.', 'type' => 'string', ), ), ), 'Aliases' => array( 'description' => 'A complex type that contains information about CNAMEs (alternate domain names), if any, for this streaming distribution.', 'type' => 'object', 'properties' => array( 'Quantity' => array( 'description' => 'The number of CNAMEs, if any, for this distribution.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains CNAME elements, if any, for this distribution. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'description' => 'Any comments you want to include about the streaming distribution.', 'type' => 'string', ), 'Logging' => array( 'description' => 'A complex type that controls whether access logs are written for the streaming distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket. If you do not want to enable logging when you create a distribution or if you want to disable logging for an existing distribution, specify false for Enabled, and specify empty Bucket and Prefix elements. If you specify false for Enabled but you specify values for Bucket and Prefix, the values are automatically deleted.', 'type' => 'boolean', ), 'Bucket' => array( 'description' => 'The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com.', 'type' => 'string', ), 'Prefix' => array( 'description' => 'An optional string that you want CloudFront to prefix to the access log filenames for this distribution, for example, myprefix/. If you want to enable logging, but you do not want to specify a prefix, you still must include an empty Prefix element in the Logging element.', 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'description' => 'A complex type that specifies the AWS accounts, if any, that you want to allow to create signed URLs for private content. If you want to require signed URLs in requests for objects in the target origin that match the PathPattern for this cache behavior, specify true for Enabled, and specify the applicable values for Quantity and Items. For more information, go to Using a Signed URL to Serve Private Content in the Amazon CloudFront Developer Guide. If you don\'t want to require signed URLs in requests for objects that match PathPattern, specify false for Enabled and 0 for Quantity. Omit Items. To add, change, or remove one or more trusted signers, change Enabled to true (if it\'s currently false), change Quantity as applicable, and specify all of the trusted signers that you want to include in the updated distribution.', 'type' => 'object', 'properties' => array( 'Enabled' => array( 'description' => 'Specifies whether you want to require end users to use signed URLs to access the files specified by PathPattern and TargetOriginId.', 'type' => 'boolean', ), 'Quantity' => array( 'description' => 'The number of trusted signers for this cache behavior.', 'type' => 'numeric', ), 'Items' => array( 'description' => 'Optional: A complex type that contains trusted signers for this cache behavior. If Quantity is 0, you can omit Items.', 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Enabled' => array( 'description' => 'Whether the streaming distribution is enabled to accept end user requests for content.', 'type' => 'boolean', ), ), ), 'ETag' => array( 'description' => 'The current version of the configuration. For example: E2QWRUHAPOMQZL.', 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'description' => 'Request ID of the operation', 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), ), 'waiters' => array( '__default__' => array( 'success.type' => 'output', 'success.path' => 'Status', ), 'StreamingDistributionDeployed' => array( 'operation' => 'GetStreamingDistribution', 'description' => 'Wait until a streaming distribution is deployed.', 'interval' => 60, 'max_attempts' => 25, 'success.value' => 'Deployed', ), 'DistributionDeployed' => array( 'operation' => 'GetDistribution', 'description' => 'Wait until a distribution is deployed.', 'interval' => 60, 'max_attempts' => 25, 'success.value' => 'Deployed', ), 'InvalidationCompleted' => array( 'operation' => 'GetInvalidation', 'description' => 'Wait until an invalidation has completed.', 'interval' => 20, 'max_attempts' => 30, 'success.value' => 'Completed', ), ), ); '2013-11-11', 'endpointPrefix' => 'cloudfront', 'serviceFullName' => 'Amazon CloudFront', 'serviceAbbreviation' => 'CloudFront', 'serviceType' => 'rest-xml', 'globalEndpoint' => 'cloudfront.amazonaws.com', 'signatureVersion' => 'v4', 'namespace' => 'CloudFront', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'cloudfront.amazonaws.com', ), ), 'operations' => array( 'CreateCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/2013-11-11/origin-access-identity/cloudfront', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'CloudFrontOriginAccessIdentityConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'If the CallerReference is a value you already sent in a previous request to create an identity but the content of the CloudFrontOriginAccessIdentityConfig is different from the original request, CloudFront returns a CloudFrontOriginAccessIdentityAlreadyExists error.', 'class' => 'CloudFrontOriginAccessIdentityAlreadyExistsException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'Processing your request would cause you to exceed the maximum number of origin access identities allowed.', 'class' => 'TooManyCloudFrontOriginAccessIdentitiesException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateDistribution' => array( 'httpMethod' => 'POST', 'uri' => '/2013-11-11/distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateDistributionResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'DistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'DefaultRootObject' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Origin', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'DomainName' => array( 'required' => true, 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'required' => true, 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'required' => true, 'type' => 'numeric', ), 'HTTPSPort' => array( 'required' => true, 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'required' => true, 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Cookies' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Forward' => array( 'required' => true, 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), 'MinTTL' => array( 'required' => true, 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', ), ), ), ), ), ), 'CacheBehaviors' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'properties' => array( 'PathPattern' => array( 'required' => true, 'type' => 'string', ), 'TargetOriginId' => array( 'required' => true, 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Cookies' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Forward' => array( 'required' => true, 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), 'MinTTL' => array( 'required' => true, 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'properties' => array( 'ErrorCode' => array( 'required' => true, 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'IncludeCookies' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), ), ), 'PriceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'ViewerCertificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'Restrictions' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'GeoRestriction' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'required' => true, 'type' => 'string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', ), ), ), ), ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'reason' => 'The caller reference you attempted to create the distribution with is associated with another distribution.', 'class' => 'DistributionAlreadyExistsException', ), array( 'reason' => 'The Amazon S3 origin server specified does not refer to a valid Amazon S3 bucket.', 'class' => 'InvalidOriginException', ), array( 'reason' => 'The origin access identity is not valid or doesn\'t exist.', 'class' => 'InvalidOriginAccessIdentityException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Your request contains more trusted signers than are allowed per distribution.', 'class' => 'TooManyTrustedSignersException', ), array( 'reason' => 'One or more of your trusted signers do not exist.', 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'InvalidViewerCertificateException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'Your request contains more CNAMEs than are allowed per distribution.', 'class' => 'TooManyDistributionCNAMEsException', ), array( 'reason' => 'Processing your request would cause you to exceed the maximum number of distributions allowed.', 'class' => 'TooManyDistributionsException', ), array( 'reason' => 'The default root object file name is too big or contains an invalid character.', 'class' => 'InvalidDefaultRootObjectException', ), array( 'reason' => 'The relative path is too big, is not URL-encoded, or does not begin with a slash (/).', 'class' => 'InvalidRelativePathException', ), array( 'class' => 'InvalidErrorCodeException', ), array( 'class' => 'InvalidResponseCodeException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'This operation requires the HTTPS protocol. Ensure that you specify the HTTPS protocol in your request, or omit the RequiredProtocols element from your distribution configuration.', 'class' => 'InvalidRequiredProtocolException', ), array( 'reason' => 'No origin exists with the specified Origin Id.', 'class' => 'NoSuchOriginException', ), array( 'reason' => 'You cannot create anymore origins for the distribution.', 'class' => 'TooManyOriginsException', ), array( 'reason' => 'You cannot create anymore cache behaviors for the distribution.', 'class' => 'TooManyCacheBehaviorsException', ), array( 'reason' => 'Your request contains more cookie names in the whitelist than are allowed per cache behavior.', 'class' => 'TooManyCookieNamesInWhiteListException', ), array( 'reason' => 'Your request contains forward cookies option which doesn\'t match with the expectation for the whitelisted list of cookie names. Either list of cookie names has been specified when not allowed or list of cookie names is missing when expected.', 'class' => 'InvalidForwardCookiesException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), array( 'reason' => 'You cannot create anymore custom ssl certificates.', 'class' => 'TooManyCertificatesException', ), array( 'class' => 'InvalidLocationCodeException', ), array( 'class' => 'InvalidGeoRestrictionParameterException', ), ), ), 'CreateInvalidation' => array( 'httpMethod' => 'POST', 'uri' => '/2013-11-11/distribution/{DistributionId}/invalidation', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateInvalidationResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'InvalidationBatch', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'DistributionId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Paths' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', ), ), ), ), 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'class' => 'BatchTooLargeException', ), array( 'reason' => 'You have exceeded the maximum number of allowable InProgress invalidation batch requests, or invalidation objects.', 'class' => 'TooManyInvalidationsInProgressException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), 'CreateStreamingDistribution' => array( 'httpMethod' => 'POST', 'uri' => '/2013-11-11/streaming-distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateStreamingDistributionResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'StreamingDistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'required' => true, 'type' => 'string', ), 'OriginAccessIdentity' => array( 'required' => true, 'type' => 'string', ), ), ), 'Aliases' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'PriceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'class' => 'StreamingDistributionAlreadyExistsException', ), array( 'reason' => 'The Amazon S3 origin server specified does not refer to a valid Amazon S3 bucket.', 'class' => 'InvalidOriginException', ), array( 'reason' => 'The origin access identity is not valid or doesn\'t exist.', 'class' => 'InvalidOriginAccessIdentityException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Your request contains more trusted signers than are allowed per distribution.', 'class' => 'TooManyTrustedSignersException', ), array( 'reason' => 'One or more of your trusted signers do not exist.', 'class' => 'TrustedSignerDoesNotExistException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'class' => 'TooManyStreamingDistributionCNAMEsException', ), array( 'reason' => 'Processing your request would cause you to exceed the maximum number of streaming distributions allowed.', 'class' => 'TooManyStreamingDistributionsException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), 'DeleteCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'DELETE', 'uri' => '/2013-11-11/origin-access-identity/cloudfront/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteCloudFrontOriginAccessIdentity2013_11_11Output', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'The specified origin access identity does not exist.', 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), array( 'class' => 'CloudFrontOriginAccessIdentityInUseException', ), ), ), 'DeleteDistribution' => array( 'httpMethod' => 'DELETE', 'uri' => '/2013-11-11/distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteDistribution2013_11_11Output', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'class' => 'DistributionNotDisabledException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), ), ), 'DeleteStreamingDistribution' => array( 'httpMethod' => 'DELETE', 'uri' => '/2013-11-11/streaming-distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteStreamingDistribution2013_11_11Output', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'class' => 'StreamingDistributionNotDisabledException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'The specified streaming distribution does not exist.', 'class' => 'NoSuchStreamingDistributionException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), ), ), 'GetCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/origin-access-identity/cloudfront/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified origin access identity does not exist.', 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetCloudFrontOriginAccessIdentityConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/origin-access-identity/cloudfront/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetCloudFrontOriginAccessIdentityConfigResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified origin access identity does not exist.', 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetDistribution' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetDistributionResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetDistributionConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetDistributionConfigResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetInvalidation' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution/{DistributionId}/invalidation/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetInvalidationResult', 'responseType' => 'model', 'parameters' => array( 'DistributionId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified invalidation does not exist.', 'class' => 'NoSuchInvalidationException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetStreamingDistribution' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/streaming-distribution/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetStreamingDistributionResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified streaming distribution does not exist.', 'class' => 'NoSuchStreamingDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'GetStreamingDistributionConfig' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/streaming-distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetStreamingDistributionConfigResult', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified streaming distribution does not exist.', 'class' => 'NoSuchStreamingDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'ListCloudFrontOriginAccessIdentities' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/origin-access-identity/cloudfront', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListCloudFrontOriginAccessIdentitiesResult', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), ), ), 'ListDistributions' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListDistributionsResult', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), ), ), 'ListInvalidations' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/distribution/{DistributionId}/invalidation', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListInvalidationsResult', 'responseType' => 'model', 'parameters' => array( 'DistributionId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Marker' => array( 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), ), ), 'ListStreamingDistributions' => array( 'httpMethod' => 'GET', 'uri' => '/2013-11-11/streaming-distribution', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListStreamingDistributionsResult', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), ), ), 'UpdateCloudFrontOriginAccessIdentity' => array( 'httpMethod' => 'PUT', 'uri' => '/2013-11-11/origin-access-identity/cloudfront/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateCloudFrontOriginAccessIdentityResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'CloudFrontOriginAccessIdentityConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Origin and CallerReference cannot be updated.', 'class' => 'IllegalUpdateException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'The specified origin access identity does not exist.', 'class' => 'NoSuchCloudFrontOriginAccessIdentityException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), 'UpdateDistribution' => array( 'httpMethod' => 'PUT', 'uri' => '/2013-11-11/distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateDistributionResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'DistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'DefaultRootObject' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Origin', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'DomainName' => array( 'required' => true, 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'required' => true, 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'required' => true, 'type' => 'numeric', ), 'HTTPSPort' => array( 'required' => true, 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'required' => true, 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Cookies' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Forward' => array( 'required' => true, 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), 'MinTTL' => array( 'required' => true, 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', ), ), ), ), ), ), 'CacheBehaviors' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'properties' => array( 'PathPattern' => array( 'required' => true, 'type' => 'string', ), 'TargetOriginId' => array( 'required' => true, 'type' => 'string', ), 'ForwardedValues' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'QueryString' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Cookies' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Forward' => array( 'required' => true, 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'ViewerProtocolPolicy' => array( 'required' => true, 'type' => 'string', ), 'MinTTL' => array( 'required' => true, 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'properties' => array( 'ErrorCode' => array( 'required' => true, 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'IncludeCookies' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), ), ), 'PriceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'ViewerCertificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'Restrictions' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'GeoRestriction' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'required' => true, 'type' => 'string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', ), ), ), ), ), ), 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'reason' => 'Origin and CallerReference cannot be updated.', 'class' => 'IllegalUpdateException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'The specified distribution does not exist.', 'class' => 'NoSuchDistributionException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), array( 'reason' => 'Your request contains more CNAMEs than are allowed per distribution.', 'class' => 'TooManyDistributionCNAMEsException', ), array( 'reason' => 'The default root object file name is too big or contains an invalid character.', 'class' => 'InvalidDefaultRootObjectException', ), array( 'reason' => 'The relative path is too big, is not URL-encoded, or does not begin with a slash (/).', 'class' => 'InvalidRelativePathException', ), array( 'class' => 'InvalidErrorCodeException', ), array( 'class' => 'InvalidResponseCodeException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The origin access identity is not valid or doesn\'t exist.', 'class' => 'InvalidOriginAccessIdentityException', ), array( 'reason' => 'Your request contains more trusted signers than are allowed per distribution.', 'class' => 'TooManyTrustedSignersException', ), array( 'reason' => 'One or more of your trusted signers do not exist.', 'class' => 'TrustedSignerDoesNotExistException', ), array( 'class' => 'InvalidViewerCertificateException', ), array( 'reason' => 'This operation requires the HTTPS protocol. Ensure that you specify the HTTPS protocol in your request, or omit the RequiredProtocols element from your distribution configuration.', 'class' => 'InvalidRequiredProtocolException', ), array( 'reason' => 'No origin exists with the specified Origin Id.', 'class' => 'NoSuchOriginException', ), array( 'reason' => 'You cannot create anymore origins for the distribution.', 'class' => 'TooManyOriginsException', ), array( 'reason' => 'You cannot create anymore cache behaviors for the distribution.', 'class' => 'TooManyCacheBehaviorsException', ), array( 'reason' => 'Your request contains more cookie names in the whitelist than are allowed per cache behavior.', 'class' => 'TooManyCookieNamesInWhiteListException', ), array( 'reason' => 'Your request contains forward cookies option which doesn\'t match with the expectation for the whitelisted list of cookie names. Either list of cookie names has been specified when not allowed or list of cookie names is missing when expected.', 'class' => 'InvalidForwardCookiesException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), array( 'reason' => 'You cannot create anymore custom ssl certificates.', 'class' => 'TooManyCertificatesException', ), array( 'class' => 'InvalidLocationCodeException', ), array( 'class' => 'InvalidGeoRestrictionParameterException', ), ), ), 'UpdateStreamingDistribution' => array( 'httpMethod' => 'PUT', 'uri' => '/2013-11-11/streaming-distribution/{Id}/config', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdateStreamingDistributionResult', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'StreamingDistributionConfig', 'namespaces' => array( 'http://cloudfront.amazonaws.com/doc/2013-11-11/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'required' => true, 'type' => 'string', ), 'OriginAccessIdentity' => array( 'required' => true, 'type' => 'string', ), ), ), 'Aliases' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', ), ), ), ), 'Comment' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Bucket' => array( 'required' => true, 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), 'Quantity' => array( 'required' => true, 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', ), ), ), ), 'PriceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Access denied.', 'class' => 'AccessDeniedException', ), array( 'class' => 'CNAMEAlreadyExistsException', ), array( 'reason' => 'Origin and CallerReference cannot be updated.', 'class' => 'IllegalUpdateException', ), array( 'reason' => 'The If-Match version is missing or not valid for the distribution.', 'class' => 'InvalidIfMatchVersionException', ), array( 'reason' => 'This operation requires a body. Ensure that the body is present and the Content-Type header is set.', 'class' => 'MissingBodyException', ), array( 'reason' => 'The specified streaming distribution does not exist.', 'class' => 'NoSuchStreamingDistributionException', ), array( 'reason' => 'The precondition given in one or more of the request-header fields evaluated to false.', 'class' => 'PreconditionFailedException', ), array( 'class' => 'TooManyStreamingDistributionCNAMEsException', ), array( 'reason' => 'The argument is invalid.', 'class' => 'InvalidArgumentException', ), array( 'reason' => 'The origin access identity is not valid or doesn\'t exist.', 'class' => 'InvalidOriginAccessIdentityException', ), array( 'reason' => 'Your request contains more trusted signers than are allowed per distribution.', 'class' => 'TooManyTrustedSignersException', ), array( 'reason' => 'One or more of your trusted signers do not exist.', 'class' => 'TrustedSignerDoesNotExistException', ), array( 'reason' => 'The value of Quantity and the size of Items do not match.', 'class' => 'InconsistentQuantitiesException', ), ), ), ), 'models' => array( 'CreateCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'type' => 'string', ), 'Origins' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'IncludeCookies' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), 'ViewerCertificate' => array( 'type' => 'object', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateInvalidationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'CreateTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InvalidationBatch' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Paths' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', 'sentAs' => 'Path', ), ), ), ), 'CallerReference' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'S3Origin' => array( 'type' => 'object', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteCloudFrontOriginAccessIdentity2013_11_11Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteDistribution2013_11_11Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteStreamingDistribution2013_11_11Output' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetCloudFrontOriginAccessIdentityConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'type' => 'string', 'location' => 'xml', ), 'Comment' => array( 'type' => 'string', 'location' => 'xml', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'type' => 'string', ), 'Origins' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'IncludeCookies' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), 'ViewerCertificate' => array( 'type' => 'object', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetDistributionConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'type' => 'string', 'location' => 'xml', ), 'Aliases' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'type' => 'string', 'location' => 'xml', ), 'Origins' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'IncludeCookies' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'PriceClass' => array( 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'type' => 'boolean', 'location' => 'xml', ), 'ViewerCertificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetInvalidationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'CreateTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InvalidationBatch' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Paths' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Path', 'type' => 'string', 'sentAs' => 'Path', ), ), ), ), 'CallerReference' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'S3Origin' => array( 'type' => 'object', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetStreamingDistributionConfigResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CallerReference' => array( 'type' => 'string', 'location' => 'xml', ), 'S3Origin' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'type' => 'string', 'location' => 'xml', ), 'Logging' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'PriceClass' => array( 'type' => 'string', 'location' => 'xml', ), 'Enabled' => array( 'type' => 'boolean', 'location' => 'xml', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListCloudFrontOriginAccessIdentitiesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CloudFrontOriginAccessIdentitySummary', 'type' => 'object', 'sentAs' => 'CloudFrontOriginAccessIdentitySummary', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'S3CanonicalUserId' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListDistributionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DistributionSummary', 'type' => 'object', 'sentAs' => 'DistributionSummary', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'LastModifiedTime' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Origins' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), 'ViewerCertificate' => array( 'type' => 'object', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListInvalidationsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InvalidationSummary', 'type' => 'object', 'sentAs' => 'InvalidationSummary', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'CreateTime' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListStreamingDistributionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Quantity' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Items' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'StreamingDistributionSummary', 'type' => 'object', 'sentAs' => 'StreamingDistributionSummary', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'LastModifiedTime' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3Origin' => array( 'type' => 'object', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateCloudFrontOriginAccessIdentityResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'S3CanonicalUserId' => array( 'type' => 'string', 'location' => 'xml', ), 'CloudFrontOriginAccessIdentityConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'InProgressInvalidationBatches' => array( 'type' => 'numeric', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'DistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'DefaultRootObject' => array( 'type' => 'string', ), 'Origins' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Origin', 'type' => 'object', 'sentAs' => 'Origin', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'S3OriginConfig' => array( 'type' => 'object', 'properties' => array( 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'CustomOriginConfig' => array( 'type' => 'object', 'properties' => array( 'HTTPPort' => array( 'type' => 'numeric', ), 'HTTPSPort' => array( 'type' => 'numeric', ), 'OriginProtocolPolicy' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultCacheBehavior' => array( 'type' => 'object', 'properties' => array( 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), 'CacheBehaviors' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheBehavior', 'type' => 'object', 'sentAs' => 'CacheBehavior', 'properties' => array( 'PathPattern' => array( 'type' => 'string', ), 'TargetOriginId' => array( 'type' => 'string', ), 'ForwardedValues' => array( 'type' => 'object', 'properties' => array( 'QueryString' => array( 'type' => 'boolean', ), 'Cookies' => array( 'type' => 'object', 'properties' => array( 'Forward' => array( 'type' => 'string', ), 'WhitelistedNames' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Name', 'type' => 'string', 'sentAs' => 'Name', ), ), ), ), ), ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'ViewerProtocolPolicy' => array( 'type' => 'string', ), 'MinTTL' => array( 'type' => 'numeric', ), 'AllowedMethods' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Method', 'type' => 'string', 'sentAs' => 'Method', ), ), ), ), ), ), ), ), ), 'CustomErrorResponses' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CustomErrorResponse', 'type' => 'object', 'sentAs' => 'CustomErrorResponse', 'properties' => array( 'ErrorCode' => array( 'type' => 'numeric', ), 'ResponsePagePath' => array( 'type' => 'string', ), 'ResponseCode' => array( 'type' => 'string', ), 'ErrorCachingMinTTL' => array( 'type' => 'numeric', ), ), ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'IncludeCookies' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), 'ViewerCertificate' => array( 'type' => 'object', 'properties' => array( 'IAMCertificateId' => array( 'type' => 'string', ), 'CloudFrontDefaultCertificate' => array( 'type' => 'boolean', ), ), ), 'Restrictions' => array( 'type' => 'object', 'properties' => array( 'GeoRestriction' => array( 'type' => 'object', 'properties' => array( 'RestrictionType' => array( 'type' => 'string', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Location', 'type' => 'string', 'sentAs' => 'Location', ), ), ), ), ), ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UpdateStreamingDistributionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Id' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModifiedTime' => array( 'type' => 'string', 'location' => 'xml', ), 'DomainName' => array( 'type' => 'string', 'location' => 'xml', ), 'ActiveTrustedSigners' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'Signer', 'type' => 'object', 'sentAs' => 'Signer', 'properties' => array( 'AwsAccountNumber' => array( 'type' => 'string', ), 'KeyPairIds' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyPairId', 'type' => 'string', 'sentAs' => 'KeyPairId', ), ), ), ), ), ), ), ), ), 'StreamingDistributionConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CallerReference' => array( 'type' => 'string', ), 'S3Origin' => array( 'type' => 'object', 'properties' => array( 'DomainName' => array( 'type' => 'string', ), 'OriginAccessIdentity' => array( 'type' => 'string', ), ), ), 'Aliases' => array( 'type' => 'object', 'properties' => array( 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'CNAME', 'type' => 'string', 'sentAs' => 'CNAME', ), ), ), ), 'Comment' => array( 'type' => 'string', ), 'Logging' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), ), ), 'TrustedSigners' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), 'Quantity' => array( 'type' => 'numeric', ), 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AwsAccountNumber', 'type' => 'string', 'sentAs' => 'AwsAccountNumber', ), ), ), ), 'PriceClass' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), ), 'waiters' => array( '__default__' => array( 'success.type' => 'output', 'success.path' => 'Status', ), 'StreamingDistributionDeployed' => array( 'operation' => 'GetStreamingDistribution', 'interval' => 60, 'max_attempts' => 25, 'success.value' => 'Deployed', ), 'DistributionDeployed' => array( 'operation' => 'GetDistribution', 'interval' => 60, 'max_attempts' => 25, 'success.value' => 'Deployed', ), 'InvalidationCompleted' => array( 'operation' => 'GetInvalidation', 'interval' => 20, 'max_attempts' => 30, 'success.value' => 'Completed', ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudsearch-%s.php' )) ->build(); } } '2011-02-01', 'endpointPrefix' => 'cloudsearch', 'serviceFullName' => 'Amazon CloudSearch', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'CloudSearch', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.eu-west-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudsearch.ap-southeast-1.amazonaws.com', ), ), 'operations' => array( 'CreateDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateDomainResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDomain', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), ), ), 'DefineIndexField' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DefineIndexFieldResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DefineIndexField', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'IndexField' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'IndexFieldName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'IndexFieldType' => array( 'required' => true, 'type' => 'string', ), 'UIntOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'numeric', ), ), ), 'LiteralOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), 'SearchEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'FacetEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'ResultEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'TextOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), 'FacetEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'ResultEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'TextProcessor' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'SourceAttributes' => array( 'type' => 'array', 'sentAs' => 'SourceAttributes.member', 'items' => array( 'name' => 'SourceAttribute', 'type' => 'object', 'properties' => array( 'SourceDataFunction' => array( 'required' => true, 'type' => 'string', ), 'SourceDataCopy' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), ), ), 'SourceDataTrimTitle' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), 'Separator' => array( 'type' => 'string', ), 'Language' => array( 'type' => 'string', ), ), ), 'SourceDataMap' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'DefaultValue' => array( 'type' => 'string', 'maxLength' => 1024, ), 'Cases' => array( 'type' => 'object', 'sentAs' => 'Cases.entry', 'additionalProperties' => array( 'type' => 'string', 'maxLength' => 1024, 'data' => array( 'shape_name' => 'FieldValue', ), ), ), ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DefineRankExpression' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DefineRankExpressionResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DefineRankExpression', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'RankExpression' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'RankName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'RankExpression' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 10240, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeleteDomainResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDomain', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), ), ), 'DeleteIndexField' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeleteIndexFieldResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteIndexField', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'IndexFieldName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteRankExpression' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeleteRankExpressionResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRankExpression', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'RankName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeDefaultSearchField' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeDefaultSearchFieldResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDefaultSearchField', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeDomains' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeDomainsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDomains', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DomainNames.member', 'items' => array( 'name' => 'DomainName', 'type' => 'string', 'minLength' => 3, 'maxLength' => 28, ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), ), ), 'DescribeIndexFields' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeIndexFieldsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeIndexFields', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'FieldNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'FieldNames.member', 'items' => array( 'name' => 'FieldName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeRankExpressions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeRankExpressionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeRankExpressions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'RankNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'RankNames.member', 'items' => array( 'name' => 'FieldName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeServiceAccessPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeServiceAccessPoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeServiceAccessPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeStemmingOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStemmingOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStemmingOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeStopwordOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeStopwordOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeStopwordOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeSynonymOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSynonymOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSynonymOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'IndexDocuments' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'IndexDocumentsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'IndexDocuments', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateDefaultSearchField' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateDefaultSearchFieldResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateDefaultSearchField', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'DefaultSearchField' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateServiceAccessPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateServiceAccessPoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateServiceAccessPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'AccessPolicies' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), ), ), 'UpdateStemmingOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateStemmingOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateStemmingOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'Stems' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateStopwordOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateStopwordOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateStopwordOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'Stopwords' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateSynonymOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateSynonymOptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateSynonymOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-02-01', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 28, ), 'Synonyms' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred while processing the request.', 'class' => 'BaseException', ), array( 'reason' => 'An internal error occurred while processing the request. If this problem persists, report an issue from the Service Health Dashboard.', 'class' => 'InternalException', ), array( 'reason' => 'The request was rejected because it specified an invalid type definition.', 'class' => 'InvalidTypeException', ), array( 'reason' => 'The request was rejected because a resource limit has already been met.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to reference a resource that does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), ), 'models' => array( 'CreateDomainResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DomainStatus' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainId' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'Created' => array( 'type' => 'boolean', ), 'Deleted' => array( 'type' => 'boolean', ), 'NumSearchableDocs' => array( 'type' => 'numeric', ), 'DocService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'SearchService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'RequiresIndexDocuments' => array( 'type' => 'boolean', ), 'Processing' => array( 'type' => 'boolean', ), 'SearchInstanceType' => array( 'type' => 'string', ), 'SearchPartitionCount' => array( 'type' => 'numeric', ), 'SearchInstanceCount' => array( 'type' => 'numeric', ), ), ), ), ), 'DefineIndexFieldResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IndexField' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'IndexFieldName' => array( 'type' => 'string', ), 'IndexFieldType' => array( 'type' => 'string', ), 'UIntOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'numeric', ), ), ), 'LiteralOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'SearchEnabled' => array( 'type' => 'boolean', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), ), ), 'TextOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), 'TextProcessor' => array( 'type' => 'string', ), ), ), 'SourceAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceAttribute', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SourceDataFunction' => array( 'type' => 'string', ), 'SourceDataCopy' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), ), ), 'SourceDataTrimTitle' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Separator' => array( 'type' => 'string', ), 'Language' => array( 'type' => 'string', ), ), ), 'SourceDataMap' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Cases' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), ), ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DefineRankExpressionResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RankExpression' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'RankName' => array( 'type' => 'string', ), 'RankExpression' => array( 'type' => 'string', ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DeleteDomainResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DomainStatus' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DomainId' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'Created' => array( 'type' => 'boolean', ), 'Deleted' => array( 'type' => 'boolean', ), 'NumSearchableDocs' => array( 'type' => 'numeric', ), 'DocService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'SearchService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'RequiresIndexDocuments' => array( 'type' => 'boolean', ), 'Processing' => array( 'type' => 'boolean', ), 'SearchInstanceType' => array( 'type' => 'string', ), 'SearchPartitionCount' => array( 'type' => 'numeric', ), 'SearchInstanceCount' => array( 'type' => 'numeric', ), ), ), ), ), 'DeleteIndexFieldResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IndexField' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'IndexFieldName' => array( 'type' => 'string', ), 'IndexFieldType' => array( 'type' => 'string', ), 'UIntOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'numeric', ), ), ), 'LiteralOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'SearchEnabled' => array( 'type' => 'boolean', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), ), ), 'TextOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), 'TextProcessor' => array( 'type' => 'string', ), ), ), 'SourceAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceAttribute', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SourceDataFunction' => array( 'type' => 'string', ), 'SourceDataCopy' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), ), ), 'SourceDataTrimTitle' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Separator' => array( 'type' => 'string', ), 'Language' => array( 'type' => 'string', ), ), ), 'SourceDataMap' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Cases' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), ), ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DeleteRankExpressionResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RankExpression' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'RankName' => array( 'type' => 'string', ), 'RankExpression' => array( 'type' => 'string', ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeDefaultSearchFieldResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DefaultSearchField' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeDomainsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DomainStatusList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DomainStatus', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'DomainId' => array( 'type' => 'string', ), 'DomainName' => array( 'type' => 'string', ), 'Created' => array( 'type' => 'boolean', ), 'Deleted' => array( 'type' => 'boolean', ), 'NumSearchableDocs' => array( 'type' => 'numeric', ), 'DocService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'SearchService' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), ), ), 'RequiresIndexDocuments' => array( 'type' => 'boolean', ), 'Processing' => array( 'type' => 'boolean', ), 'SearchInstanceType' => array( 'type' => 'string', ), 'SearchPartitionCount' => array( 'type' => 'numeric', ), 'SearchInstanceCount' => array( 'type' => 'numeric', ), ), ), ), ), ), 'DescribeIndexFieldsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IndexFields' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'IndexFieldStatus', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'IndexFieldName' => array( 'type' => 'string', ), 'IndexFieldType' => array( 'type' => 'string', ), 'UIntOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'numeric', ), ), ), 'LiteralOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'SearchEnabled' => array( 'type' => 'boolean', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), ), ), 'TextOptions' => array( 'type' => 'object', 'properties' => array( 'DefaultValue' => array( 'type' => 'string', ), 'FacetEnabled' => array( 'type' => 'boolean', ), 'ResultEnabled' => array( 'type' => 'boolean', ), 'TextProcessor' => array( 'type' => 'string', ), ), ), 'SourceAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceAttribute', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SourceDataFunction' => array( 'type' => 'string', ), 'SourceDataCopy' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), ), ), 'SourceDataTrimTitle' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Separator' => array( 'type' => 'string', ), 'Language' => array( 'type' => 'string', ), ), ), 'SourceDataMap' => array( 'type' => 'object', 'properties' => array( 'SourceName' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Cases' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), ), ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'DescribeRankExpressionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RankExpressions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'RankExpressionStatus', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Options' => array( 'type' => 'object', 'properties' => array( 'RankName' => array( 'type' => 'string', ), 'RankExpression' => array( 'type' => 'string', ), ), ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'DescribeServiceAccessPoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccessPolicies' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeStemmingOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stems' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeStopwordOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stopwords' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeSynonymOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Synonyms' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'IndexDocumentsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'FieldNames' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'FieldName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'UpdateDefaultSearchFieldResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DefaultSearchField' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'UpdateServiceAccessPoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccessPolicies' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'UpdateStemmingOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stems' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'UpdateStopwordOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stopwords' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'UpdateSynonymOptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Synonyms' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Options' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'UpdateDate' => array( 'type' => 'string', ), 'UpdateVersion' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'PendingDeletion' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeDomains' => array( 'result_key' => 'DomainStatusList', ), 'DescribeIndexFields' => array( 'result_key' => 'IndexFields', ), 'DescribeRankExpressions' => array( 'result_key' => 'RankExpressions', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudtrail-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } describeTrails(array( 'trailNameList' => array($trailName), )); $s3BucketName = $result->getPath('trailList/0/S3BucketName'); $options[self::KEY_PREFIX] = $result->getPath('trailList/0/S3KeyPrefix'); } catch (CloudTrailException $e) { // There was an error describing the trail } // If the bucket name is still unknown, then throw an exception if (!$s3BucketName) { $prev = isset($e) ? $e : null; throw new InvalidArgumentException('The bucket name could not be determined from the trail.', 0, $prev); } return new self($s3Client, $s3BucketName, $options); } /** * Constructs a LogFileIterator using the specified options: * * - trail_name: The name of the trail that is generating our logs. If none is provided, then "Default" will be * used, since that is the name of the trail created in the AWS Management Console. * - key_prefix: The S3 key prefix of your log files. This value will be overwritten when using the `fromTrail()` * method. However, if you are using the constructor, then this value will be used. * - start_date: The timestamp of the beginning of date range of the log records you want to read. You can pass this * in as a `DateTime` object, integer (unix timestamp), or a string compatible with `strtotime()`. * - end_date: The timestamp of the end of date range of the log records you want to read. You can pass this in as * a `DateTime` object, integer (unix timestamp), or a string compatible with `strtotime()`. * - account_id: This is your AWS account ID, which is the 12-digit number found on the *Account Identifiers* * section of the *AWS Security Credentials* page. See https://console.aws.amazon.com/iam/home?#security_credential * - log_region: The region of the services of the log records you want to read. * * @param S3Client $s3Client * @param string $s3BucketName * @param array $options */ public function __construct(S3Client $s3Client, $s3BucketName, array $options = array()) { $this->s3Client = $s3Client; $this->s3BucketName = $s3BucketName; parent::__construct($this->buildListObjectsIterator($options)); } /** * An override of the typical current behavior of \IteratorIterator to format the output such that the bucket and * key are returned in an array * * @return array|bool */ public function current() { if ($object = parent::current()) { return array( 'Bucket' => $this->s3BucketName, 'Key' => $object['Key'] ); } return false; } /** * Constructs an S3 ListObjects iterator, optionally decorated with FilterIterators, based on the provided options * * @param array $options * * @return \Iterator */ private function buildListObjectsIterator(array $options) { // Extract and normalize the date values from the options $startDate = isset($options[self::START_DATE]) ? $this->normalizeDateValue($options[self::START_DATE]) : null; $endDate = isset($options[self::END_DATE]) ? $this->normalizeDateValue($options[self::END_DATE]) : null; // Determine the parts of the key prefix of the log files being read $keyPrefixParts = array( 'prefix' => isset($options[self::KEY_PREFIX]) ? $options[self::KEY_PREFIX] : null, 'account' => isset($options[self::ACCOUNT_ID]) ? $options[self::ACCOUNT_ID] : self::PREFIX_WILDCARD, 'region' => isset($options[self::LOG_REGION]) ? $options[self::LOG_REGION] : self::PREFIX_WILDCARD, 'date' => $this->determineDateForPrefix($startDate, $endDate), ); // Determine the longest key prefix that can be used to retrieve all of the relevant log files $candidatePrefix = ltrim(strtr(self::PREFIX_TEMPLATE, $keyPrefixParts), '/'); $logKeyPrefix = $candidatePrefix; if (($index = strpos($candidatePrefix, self::PREFIX_WILDCARD)) !== false) { $logKeyPrefix = substr($candidatePrefix, 0, $index); } // Create an iterator that will emit all of the objects matching the key prefix $objectsIterator = $this->s3Client->getListObjectsIterator(array( 'Bucket' => $this->s3BucketName, 'Prefix' => $logKeyPrefix, )); // Apply regex and/or date filters to the objects iterator to emit only log files matching the options $objectsIterator = $this->applyRegexFilter($objectsIterator, $logKeyPrefix, $candidatePrefix); $objectsIterator = $this->applyDateFilter($objectsIterator, $startDate, $endDate); return $objectsIterator; } /** * Normalizes a date value to a unix timestamp * * @param string|\DateTime|int $date * * @return int * @throws \InvalidArgumentException if the value cannot be converted to a timestamp */ private function normalizeDateValue($date) { // Normalize start date to a unix timestamp if (is_string($date)) { $date = strtotime($date); } elseif ($date instanceof \DateTime) { $date = $date->format('U'); } elseif (!is_int($date)) { throw new \InvalidArgumentException('Date values must be a string, an int, or a DateTime object.'); } return $date; } /** * Uses the provided date values to determine the date portion of the prefix */ private function determineDateForPrefix($startDate, $endDate) { // The default date value should look like "*/*/*" after joining $dateParts = array_fill_keys(array('Y', 'm', 'd'), self::PREFIX_WILDCARD); // Narrow down the date by replacing the WILDCARDs with values if they are the same for the start and end date if ($startDate && $endDate) { foreach ($dateParts as $key => &$value) { $candidateValue = date($key, $startDate); if ($candidateValue === date($key, $endDate)) { $value = $candidateValue; } else { break; } } } return join('/', $dateParts); } /** * Applies a regex iterator filter that limits the ListObjects result set based on the provided options * * @param \Iterator $objectsIterator * @param string $logKeyPrefix * @param string $candidatePrefix * * @return \Iterator */ private function applyRegexFilter($objectsIterator, $logKeyPrefix, $candidatePrefix) { // If the prefix and candidate prefix are not the same, then there were WILDCARDs if ($logKeyPrefix !== $candidatePrefix) { // Turn the candidate prefix into a regex by trimming and converting WILDCARDs to regex notation $regex = rtrim($candidatePrefix, '/' . self::PREFIX_WILDCARD) . '/'; $regex = strtr($regex, array(self::PREFIX_WILDCARD => '[^/]+')); // After trimming WILDCARDs or the end, if the regex is the same as the prefix, then no regex is needed if ($logKeyPrefix !== $regex) { // Apply a regex filter iterator to remove files that don't match the provided options $objectsIterator = new FilterIterator($objectsIterator, function ($object) use ($regex) { return preg_match("#{$regex}#", $object['Key']); }); } } return $objectsIterator; } /** * Applies an iterator filter to restrict the ListObjects result set to the specified date range * * @param \Iterator $objectsIterator * @param int $startDate * @param int $endDate * * @return \Iterator */ private function applyDateFilter($objectsIterator, $startDate, $endDate) { // If either a start or end date was provided, filter out dates that don't match the date range if ($startDate || $endDate) { $objectsIterator = new FilterIterator($objectsIterator, function ($object) use ($startDate, $endDate) { if (preg_match('/[0-9]{8}T[0-9]{4}Z/', $object['Key'], $matches)) { $date = strtotime($matches[0]); if ((!$startDate || $date >= $startDate) && (!$endDate || $date <= $endDate)) { return true; } } return false; }); } return $objectsIterator; } } s3Client = $s3Client; } /** * Downloads, unzips, and reads a CloudTrail log file from Amazon S3 * * @param string $s3BucketName The bucket name of the log file in Amazon S3 * @param string $logFileKey The key of the log file in Amazon S3 * * @return array */ public function read($s3BucketName, $logFileKey) { // Create a command for getting the log file object $command = $this->s3Client->getCommand('GetObject', array( 'Bucket' => (string) $s3BucketName, 'Key' => (string) $logFileKey, )); // Make sure gzip encoding header is sent and accepted in order to inflate the response data $command->set('ResponseContentEncoding', 'x-gzip'); $command->prepare()->addHeader('Accept-Encoding', 'gzip'); // Get the JSON response data and extract the log records $command->execute(); $logData = $command->getResponse()->json(); if (isset($logData['Records'])) { return $logData['Records']; } else { return array(); } } } $s3BucketName, 'Key' => $s3ObjectKey, ))); return new self($logFileReader, $logFileIterator); } /** * @param LogFileReader $logFileReader * @param \Iterator $logFileIterator */ public function __construct(LogFileReader $logFileReader, \Iterator $logFileIterator) { $this->logFileReader = $logFileReader; $this->logFileIterator = $logFileIterator; $this->records = array(); $this->recordIndex = 0; } /** * Returns the current log record as a Guzzle Collection object. This object behaves like an associative array * except that it returns `null` on non-existent keys instead of causing an error. See the linked resources for the * schema of the log record data and how to work with Guzzle Collections. * * @return Collection * @link http://docs.aws.amazon.com/awscloudtrail/latest/userguide/eventreference.html * @link http://api.guzzlephp.org/class-Guzzle.Common.Collection.html */ public function current() { if ($this->valid()) { return new Collection($this->records[$this->recordIndex]); } else { return false; } } public function next() { $this->recordIndex++; // If all the records have been exhausted, get more records from the next log file while (!$this->valid()) { $this->logFileIterator->next(); $success = $this->loadRecordsFromCurrentLogFile(); if (!$success) { // The objects iterator is exhausted as well, so stop trying break; } } } public function key() { if ($logFile = $this->logFileIterator->current()) { return $logFile['Key'] . '.' . $this->recordIndex; } else { return null; } } public function valid() { return isset($this->records[$this->recordIndex]); } public function rewind() { $this->logFileIterator->rewind(); $this->loadRecordsFromCurrentLogFile(); } public function getInnerIterator() { return $this->logFileIterator; } /** * Examines the current file in the `logFileIterator` and attempts to read it and load log records from it using * the `logFileReader`. This method expects that items pulled from the iterator will take the form: * * array( * 'Bucket' => '...', * 'Key' => '...', * ) * * @return bool Returns `true` if records were loaded and `false` if no records were found */ private function loadRecordsFromCurrentLogFile() { $this->recordIndex = 0; $this->records = array(); $logFile = $this->logFileIterator->current(); if ($logFile && isset($logFile['Bucket']) && isset($logFile['Key'])) { $this->records = $this->logFileReader->read($logFile['Bucket'], $logFile['Key']); } return (bool) $logFile; } } '2013-11-01', 'endpointPrefix' => 'cloudtrail', 'serviceFullName' => 'AWS CloudTrail', 'serviceAbbreviation' => 'CloudTrail', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.', 'signatureVersion' => 'v4', 'namespace' => 'CloudTrail', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudtrail.us-east-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'cloudtrail.us-west-2.amazonaws.com', ), ), 'operations' => array( 'CreateTrail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateTrailResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.CreateTrail', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'S3BucketName' => array( 'type' => 'string', 'location' => 'json', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'json', ), 'SnsTopicName' => array( 'type' => 'string', 'location' => 'json', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'trail' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the maximum number of trails is reached.', 'class' => 'MaximumNumberOfTrailsExceededException', ), array( 'reason' => 'This exception is thrown when the specified trail already exists.', 'class' => 'TrailAlreadyExistsException', ), array( 'reason' => 'This exception is thrown when the specified S3 bucket does not exist.', 'class' => 'S3BucketDoesNotExistException', ), array( 'reason' => 'This exception is thrown when the policy on the S3 bucket is not sufficient.', 'class' => 'InsufficientS3BucketPolicyException', ), array( 'reason' => 'This exception is thrown when the policy on the SNS topic is not sufficient.', 'class' => 'InsufficientSnsTopicPolicyException', ), array( 'reason' => 'This exception is thrown when the provided S3 bucket name is not valid.', 'class' => 'InvalidS3BucketNameException', ), array( 'reason' => 'This exception is thrown when the provided S3 prefix is not valid.', 'class' => 'InvalidS3PrefixException', ), array( 'reason' => 'This exception is thrown when the provided SNS topic name is not valid.', 'class' => 'InvalidSnsTopicNameException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), array( 'reason' => 'This exception is thrown when no trail is provided.', 'class' => 'TrailNotProvidedException', ), ), ), 'DeleteTrail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.DeleteTrail', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), ), ), 'DescribeTrails' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrailsResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.DescribeTrails', ), 'trailNameList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'GetTrailStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetTrailStatusResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.GetTrailStatus', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), ), ), 'StartLogging' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.StartLogging', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), ), ), 'StopLogging' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.StopLogging', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), ), ), 'UpdateTrail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateTrailResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.UpdateTrail', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'S3BucketName' => array( 'type' => 'string', 'location' => 'json', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'json', ), 'SnsTopicName' => array( 'type' => 'string', 'location' => 'json', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'trail' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the specified S3 bucket does not exist.', 'class' => 'S3BucketDoesNotExistException', ), array( 'reason' => 'This exception is thrown when the policy on the S3 bucket is not sufficient.', 'class' => 'InsufficientS3BucketPolicyException', ), array( 'reason' => 'This exception is thrown when the policy on the SNS topic is not sufficient.', 'class' => 'InsufficientSnsTopicPolicyException', ), array( 'reason' => 'This exception is thrown when the trail with the given name is not found.', 'class' => 'TrailNotFoundException', ), array( 'reason' => 'This exception is thrown when the provided S3 bucket name is not valid.', 'class' => 'InvalidS3BucketNameException', ), array( 'reason' => 'This exception is thrown when the provided S3 prefix is not valid.', 'class' => 'InvalidS3PrefixException', ), array( 'reason' => 'This exception is thrown when the provided SNS topic name is not valid.', 'class' => 'InvalidSnsTopicNameException', ), array( 'reason' => 'This exception is thrown when the provided trail name is not valid.', 'class' => 'InvalidTrailNameException', ), array( 'reason' => 'This exception is thrown when no trail is provided.', 'class' => 'TrailNotProvidedException', ), ), ), ), 'models' => array( 'CreateTrailResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'S3BucketName' => array( 'type' => 'string', 'location' => 'json', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'json', ), 'SnsTopicName' => array( 'type' => 'string', 'location' => 'json', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'location' => 'json', ), 'trail' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeTrailsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'trailList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Trail', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', ), ), ), ), ), ), 'GetTrailStatusResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IsLogging' => array( 'type' => 'boolean', 'location' => 'json', ), 'LatestDeliveryError' => array( 'type' => 'string', 'location' => 'json', ), 'LatestNotificationError' => array( 'type' => 'string', 'location' => 'json', ), 'LatestDeliveryTime' => array( 'type' => 'string', 'location' => 'json', ), 'LatestNotificationTime' => array( 'type' => 'string', 'location' => 'json', ), 'StartLoggingTime' => array( 'type' => 'string', 'location' => 'json', ), 'StopLoggingTime' => array( 'type' => 'string', 'location' => 'json', ), 'LatestDeliveryAttemptTime' => array( 'type' => 'string', 'location' => 'json', ), 'LatestNotificationAttemptTime' => array( 'type' => 'string', 'location' => 'json', ), 'LatestNotificationAttemptSucceeded' => array( 'type' => 'string', 'location' => 'json', ), 'LatestDeliveryAttemptSucceeded' => array( 'type' => 'string', 'location' => 'json', ), 'TimeLoggingStarted' => array( 'type' => 'string', 'location' => 'json', ), 'TimeLoggingStopped' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateTrailResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'S3BucketName' => array( 'type' => 'string', 'location' => 'json', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'json', ), 'SnsTopicName' => array( 'type' => 'string', 'location' => 'json', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', 'location' => 'json', ), 'trail' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'S3BucketName' => array( 'type' => 'string', ), 'S3KeyPrefix' => array( 'type' => 'string', ), 'SnsTopicName' => array( 'type' => 'string', ), 'IncludeGlobalServiceEvents' => array( 'type' => 'boolean', ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeTrails' => array( 'result_key' => 'trailList', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudwatch-%s.php' )) ->build(); } } '2010-08-01', 'endpointPrefix' => 'monitoring', 'serviceFullName' => 'Amazon CloudWatch', 'serviceAbbreviation' => 'CloudWatch', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'CloudWatch', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'monitoring.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'monitoring.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'DeleteAlarms' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAlarms', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmNames.member', 'maxItems' => 100, 'items' => array( 'name' => 'AlarmName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), 'errorResponses' => array( array( 'reason' => 'The named resource does not exist.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeAlarmHistory' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAlarmHistoryOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAlarmHistory', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'HistoryItemType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 100, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The next token specified is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeAlarms' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAlarmsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAlarms', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmNames.member', 'maxItems' => 100, 'items' => array( 'name' => 'AlarmName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), 'AlarmNamePrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'StateValue' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ActionPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 1024, ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 100, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The next token specified is invalid.', 'class' => 'InvalidNextTokenException', ), ), ), 'DescribeAlarmsForMetric' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAlarmsForMetricOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAlarmsForMetric', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'MetricName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Namespace' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Statistic' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Dimensions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'Period' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 60, ), 'Unit' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DisableAlarmActions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableAlarmActions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmNames.member', 'maxItems' => 100, 'items' => array( 'name' => 'AlarmName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'EnableAlarmActions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableAlarmActions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmNames.member', 'maxItems' => 100, 'items' => array( 'name' => 'AlarmName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'GetMetricStatistics' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetMetricStatisticsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetMetricStatistics', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'Namespace' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'MetricName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Dimensions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'StartTime' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Period' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 60, ), 'Statistics' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Statistics.member', 'minItems' => 1, 'maxItems' => 5, 'items' => array( 'name' => 'Statistic', 'type' => 'string', ), ), 'Unit' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Bad or out-of-range value was supplied for the input parameter.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'An input parameter that is mandatory for processing the request is not supplied.', 'class' => 'MissingRequiredParameterException', ), array( 'reason' => 'Parameters that must not be used together were used together.', 'class' => 'InvalidParameterCombinationException', ), array( 'reason' => 'Indicates that the request processing has failed due to some unknown error, exception, or failure.', 'class' => 'InternalServiceException', ), ), ), 'ListMetrics' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListMetricsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListMetrics', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'Namespace' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'MetricName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Dimensions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'DimensionFilter', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the request processing has failed due to some unknown error, exception, or failure.', 'class' => 'InternalServiceException', ), array( 'reason' => 'Bad or out-of-range value was supplied for the input parameter.', 'class' => 'InvalidParameterValueException', ), ), ), 'PutMetricAlarm' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutMetricAlarm', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'AlarmDescription' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 255, ), 'ActionsEnabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'OKActions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OKActions.member', 'maxItems' => 5, 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'AlarmActions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AlarmActions.member', 'maxItems' => 5, 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'InsufficientDataActions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InsufficientDataActions.member', 'maxItems' => 5, 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'MetricName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Namespace' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'Statistic' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Dimensions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'Period' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 60, ), 'Unit' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EvaluationPeriods' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, ), 'Threshold' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The quota for alarms for this customer has already been reached.', 'class' => 'LimitExceededException', ), ), ), 'PutMetricData' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutMetricData', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'Namespace' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'MetricData' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'MetricData.member', 'items' => array( 'name' => 'MetricDatum', 'type' => 'object', 'properties' => array( 'MetricName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Dimensions' => array( 'type' => 'array', 'sentAs' => 'Dimensions.member', 'maxItems' => 10, 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Value' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'Timestamp' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', ), 'Value' => array( 'type' => 'numeric', ), 'StatisticValues' => array( 'type' => 'object', 'properties' => array( 'SampleCount' => array( 'required' => true, 'type' => 'numeric', ), 'Sum' => array( 'required' => true, 'type' => 'numeric', ), 'Minimum' => array( 'required' => true, 'type' => 'numeric', ), 'Maximum' => array( 'required' => true, 'type' => 'numeric', ), ), ), 'Unit' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Bad or out-of-range value was supplied for the input parameter.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'An input parameter that is mandatory for processing the request is not supplied.', 'class' => 'MissingRequiredParameterException', ), array( 'reason' => 'Parameters that must not be used together were used together.', 'class' => 'InvalidParameterCombinationException', ), array( 'reason' => 'Indicates that the request processing has failed due to some unknown error, exception, or failure.', 'class' => 'InternalServiceException', ), ), ), 'SetAlarmState' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetAlarmState', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-08-01', ), 'AlarmName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 255, ), 'StateValue' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'StateReason' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 1023, ), 'StateReasonData' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 4000, ), ), 'errorResponses' => array( array( 'reason' => 'The named resource does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Data was not syntactically valid JSON.', 'class' => 'InvalidFormatException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeAlarmHistoryOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AlarmHistoryItems' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AlarmHistoryItem', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AlarmName' => array( 'type' => 'string', ), 'Timestamp' => array( 'type' => 'string', ), 'HistoryItemType' => array( 'type' => 'string', ), 'HistorySummary' => array( 'type' => 'string', ), 'HistoryData' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeAlarmsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MetricAlarms' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MetricAlarm', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AlarmName' => array( 'type' => 'string', ), 'AlarmArn' => array( 'type' => 'string', ), 'AlarmDescription' => array( 'type' => 'string', ), 'AlarmConfigurationUpdatedTimestamp' => array( 'type' => 'string', ), 'ActionsEnabled' => array( 'type' => 'boolean', ), 'OKActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'AlarmActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'InsufficientDataActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'StateValue' => array( 'type' => 'string', ), 'StateReason' => array( 'type' => 'string', ), 'StateReasonData' => array( 'type' => 'string', ), 'StateUpdatedTimestamp' => array( 'type' => 'string', ), 'MetricName' => array( 'type' => 'string', ), 'Namespace' => array( 'type' => 'string', ), 'Statistic' => array( 'type' => 'string', ), 'Dimensions' => array( 'type' => 'array', 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'Period' => array( 'type' => 'numeric', ), 'Unit' => array( 'type' => 'string', ), 'EvaluationPeriods' => array( 'type' => 'numeric', ), 'Threshold' => array( 'type' => 'numeric', ), 'ComparisonOperator' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DescribeAlarmsForMetricOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MetricAlarms' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MetricAlarm', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AlarmName' => array( 'type' => 'string', ), 'AlarmArn' => array( 'type' => 'string', ), 'AlarmDescription' => array( 'type' => 'string', ), 'AlarmConfigurationUpdatedTimestamp' => array( 'type' => 'string', ), 'ActionsEnabled' => array( 'type' => 'boolean', ), 'OKActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'AlarmActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'InsufficientDataActions' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceName', 'type' => 'string', 'sentAs' => 'member', ), ), 'StateValue' => array( 'type' => 'string', ), 'StateReason' => array( 'type' => 'string', ), 'StateReasonData' => array( 'type' => 'string', ), 'StateUpdatedTimestamp' => array( 'type' => 'string', ), 'MetricName' => array( 'type' => 'string', ), 'Namespace' => array( 'type' => 'string', ), 'Statistic' => array( 'type' => 'string', ), 'Dimensions' => array( 'type' => 'array', 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'Period' => array( 'type' => 'numeric', ), 'Unit' => array( 'type' => 'string', ), 'EvaluationPeriods' => array( 'type' => 'numeric', ), 'Threshold' => array( 'type' => 'numeric', ), 'ComparisonOperator' => array( 'type' => 'string', ), ), ), ), ), ), 'GetMetricStatisticsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Label' => array( 'type' => 'string', 'location' => 'xml', ), 'Datapoints' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Datapoint', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Timestamp' => array( 'type' => 'string', ), 'SampleCount' => array( 'type' => 'numeric', ), 'Average' => array( 'type' => 'numeric', ), 'Sum' => array( 'type' => 'numeric', ), 'Minimum' => array( 'type' => 'numeric', ), 'Maximum' => array( 'type' => 'numeric', ), 'Unit' => array( 'type' => 'string', ), ), ), ), ), ), 'ListMetricsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Metrics' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Metric', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'MetricName' => array( 'type' => 'string', ), 'Dimensions' => array( 'type' => 'array', 'items' => array( 'name' => 'Dimension', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeAlarmHistory' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'AlarmHistoryItems', ), 'DescribeAlarms' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'MetricAlarms', ), 'DescribeAlarmsForMetric' => array( 'result_key' => 'MetricAlarms', ), 'ListMetrics' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Metrics', ), ), ), ); addAlias('_aws', self::getDefaultServiceDefinition()) ->addAlias('_sdk1', __DIR__ . '/Resources/sdk1-config.php'); return $loader->load($config, $globalParameters); } /** * Get the full path to the default service builder definition file * * @return string */ public static function getDefaultServiceDefinition() { return __DIR__ . '/Resources/aws-config.php'; } /** * Returns the configuration for the service builder * * @return array */ public function getConfig() { return $this->builderConfig; } /** * Enables the facades for the clients defined in the service builder * * @param string|null $namespace The namespace that the facades should be mounted to. Defaults to global namespace * * @return Aws */ public function enableFacades($namespace = null) { Facade::mountFacades($this, $namespace); return $this; } } get(Options::BASE_URL), $config); $this->credentials = $credentials; $this->signature = $signature; // Make sure the user agent is prefixed by the SDK version $this->setUserAgent('aws-sdk-php2/' . Aws::VERSION, true); // Add the event listener so that requests are signed before they are sent $dispatcher = $this->getEventDispatcher(); $dispatcher->addSubscriber(new SignatureListener($credentials, $signature)); if ($backoff = $config->get(Options::BACKOFF)) { $dispatcher->addSubscriber($backoff, -255); } } public function __call($method, $args) { if (substr($method, 0, 3) === 'get' && substr($method, -8) === 'Iterator') { // Allow magic method calls for iterators (e.g. $client->getIterator($params)) $commandOptions = isset($args[0]) ? $args[0] : null; $iteratorOptions = isset($args[1]) ? $args[1] : array(); return $this->getIterator(substr($method, 3, -8), $commandOptions, $iteratorOptions); } elseif (substr($method, 0, 9) == 'waitUntil') { // Allow magic method calls for waiters (e.g. $client->waitUntil($params)) return $this->waitUntil(substr($method, 9), isset($args[0]) ? $args[0]: array()); } else { return parent::__call(ucfirst($method), $args); } } /** * Get an endpoint for a specific region from a service description * * @param ServiceDescriptionInterface $description Service description * @param string $region Region of the endpoint * @param string $scheme URL scheme * * @return string * @throws InvalidArgumentException */ public static function getEndpoint(ServiceDescriptionInterface $description, $region, $scheme) { $service = $description->getData('serviceFullName'); // Lookup the region in the service description if (!($regions = $description->getData('regions'))) { throw new InvalidArgumentException("No regions found in the {$service} description"); } // Ensure that the region exists for the service if (!isset($regions[$region])) { throw new InvalidArgumentException("{$region} is not a valid region for {$service}"); } // Ensure that the scheme is valid if ($regions[$region][$scheme] == false) { throw new InvalidArgumentException("{$scheme} is not a valid URI scheme for {$service} in {$region}"); } return $scheme . '://' . $regions[$region]['hostname']; } /** * {@inheritdoc} */ public function getCredentials() { return $this->credentials; } /** * {@inheritdoc} */ public function setCredentials(CredentialsInterface $credentials) { $formerCredentials = $this->credentials; $this->credentials = $credentials; // Dispatch an event that the credentials have been changed $this->dispatch('client.credentials_changed', array( 'credentials' => $credentials, 'former_credentials' => $formerCredentials, )); return $this; } /** * {@inheritdoc} */ public function getSignature() { return $this->signature; } /** * {@inheritdoc} */ public function getRegions() { return $this->serviceDescription->getData('regions'); } /** * {@inheritdoc} */ public function getRegion() { return $this->getConfig(Options::REGION); } /** * {@inheritdoc} */ public function setRegion($region) { $config = $this->getConfig(); $formerRegion = $config->get(Options::REGION); $global = $this->serviceDescription->getData('globalEndpoint'); // Only change the region if the service does not have a global endpoint if (!$global || $this->serviceDescription->getData('namespace') === 'S3') { $baseUrl = self::getEndpoint($this->serviceDescription, $region, $config->get(Options::SCHEME)); $this->setBaseUrl($baseUrl); $config->set(Options::BASE_URL, $baseUrl)->set(Options::REGION, $region); // Update the signature if necessary $signature = $this->getSignature(); if ($signature instanceof EndpointSignatureInterface) { /** @var $signature EndpointSignatureInterface */ $signature->setRegionName($region); } // Dispatch an event that the region has been changed $this->dispatch('client.region_changed', array( 'region' => $region, 'former_region' => $formerRegion, )); } return $this; } /** * {@inheritdoc} */ public function waitUntil($waiter, array $input = array()) { $this->getWaiter($waiter, $input)->wait(); return $this; } /** * {@inheritdoc} */ public function getWaiter($waiter, array $input = array()) { return $this->getWaiterFactory()->build($waiter) ->setClient($this) ->setConfig($input); } /** * {@inheritdoc} */ public function setWaiterFactory(WaiterFactoryInterface $waiterFactory) { $this->waiterFactory = $waiterFactory; return $this; } /** * {@inheritdoc} */ public function getWaiterFactory() { if (!$this->waiterFactory) { $clientClass = get_class($this); // Use a composite factory that checks for classes first, then config waiters $this->waiterFactory = new CompositeWaiterFactory(array( new WaiterClassFactory(substr($clientClass, 0, strrpos($clientClass, '\\')) . '\\Waiter') )); if ($this->getDescription()) { $waiterConfig = $this->getDescription()->getData('waiters') ?: array(); $this->waiterFactory->addFactory(new WaiterConfigFactory($waiterConfig)); } } return $this->waiterFactory; } /** * {@inheritdoc} */ public function getApiVersion() { return $this->serviceDescription->getApiVersion(); } /** * {@inheritdoc} * @throws \Aws\Common\Exception\TransferException */ public function send($requests) { try { return parent::send($requests); } catch (CurlException $e) { $wrapped = new TransferException($e->getMessage(), null, $e); $wrapped->setCurlHandle($e->getCurlHandle()) ->setCurlInfo($e->getCurlInfo()) ->setError($e->getError(), $e->getErrorNo()) ->setRequest($e->getRequest()); throw $wrapped; } } } 'https'); /** * @var array Default client requirements */ protected static $commonConfigRequirements = array(Options::SERVICE_DESCRIPTION); /** * @var string The namespace of the client */ protected $clientNamespace; /** * @var array The config options */ protected $config = array(); /** * @var array The config defaults */ protected $configDefaults = array(); /** * @var array The config requirements */ protected $configRequirements = array(); /** * @var ExceptionParserInterface The Parser interface for the client */ protected $exceptionParser; /** * @var array Array of configuration data for iterators available for the client */ protected $iteratorsConfig = array(); /** * Factory method for creating the client builder * * @param string $namespace The namespace of the client * * @return ClientBuilder */ public static function factory($namespace = null) { return new static($namespace); } /** * Constructs a client builder * * @param string $namespace The namespace of the client */ public function __construct($namespace = null) { $this->clientNamespace = $namespace; } /** * Sets the config options * * @param array|Collection $config The config options * * @return ClientBuilder */ public function setConfig($config) { $this->config = $this->processArray($config); return $this; } /** * Sets the config options' defaults * * @param array|Collection $defaults The default values * * @return ClientBuilder */ public function setConfigDefaults($defaults) { $this->configDefaults = $this->processArray($defaults); return $this; } /** * Sets the required config options * * @param array|Collection $required The required config options * * @return ClientBuilder */ public function setConfigRequirements($required) { $this->configRequirements = $this->processArray($required); return $this; } /** * Sets the exception parser. If one is not provided the builder will use * the default XML exception parser. * * @param ExceptionParserInterface $parser The exception parser * * @return ClientBuilder */ public function setExceptionParser(ExceptionParserInterface $parser) { $this->exceptionParser = $parser; return $this; } /** * Set the configuration for the client's iterators * * @param array $config Configuration data for client's iterators * * @return ClientBuilder */ public function setIteratorsConfig(array $config) { $this->iteratorsConfig = $config; return $this; } /** * Performs the building logic using all of the parameters that have been * set and falling back to default values. Returns an instantiate service * client with credentials prepared and plugins attached. * * @return AwsClientInterface * @throws InvalidArgumentException */ public function build() { // Resolve configuration $config = Collection::fromConfig( $this->config, array_merge(self::$commonConfigDefaults, $this->configDefaults), (self::$commonConfigRequirements + $this->configRequirements) ); // Resolve endpoint and signature from the config and service description $description = $this->updateConfigFromDescription($config); $signature = $this->getSignature($description, $config); // Resolve credentials if (!$credentials = $config->get('credentials')) { $credentials = Credentials::factory($config); } // Resolve exception parser if (!$this->exceptionParser) { $this->exceptionParser = new DefaultXmlExceptionParser(); } // Resolve backoff strategy $backoff = $config->get(Options::BACKOFF); if ($backoff === null) { $backoff = new BackoffPlugin( // Retry failed requests up to 3 times if it is determined that the request can be retried new TruncatedBackoffStrategy(3, // Retry failed requests with 400-level responses due to throttling new ThrottlingErrorChecker($this->exceptionParser, // Retry failed requests with 500-level responses new HttpBackoffStrategy(array(500, 503, 509), // Retry failed requests due to transient network or cURL problems new CurlBackoffStrategy(null, // Retry requests that failed due to expired credentials new ExpiredCredentialsChecker($this->exceptionParser, new ExponentialBackoffStrategy() ) ) ) ) ) ); $config->set(Options::BACKOFF, $backoff); } if ($backoff) { $this->addBackoffLogger($backoff, $config); } // Determine service and class name $clientClass = 'Aws\Common\Client\DefaultClient'; if ($this->clientNamespace) { $serviceName = substr($this->clientNamespace, strrpos($this->clientNamespace, '\\') + 1); $clientClass = $this->clientNamespace . '\\' . $serviceName . 'Client'; } /** @var $client AwsClientInterface */ $client = new $clientClass($credentials, $signature, $config); $client->setDescription($description); // Add exception marshaling so that more descriptive exception are thrown if ($this->clientNamespace) { $exceptionFactory = new NamespaceExceptionFactory( $this->exceptionParser, "{$this->clientNamespace}\\Exception", "{$this->clientNamespace}\\Exception\\{$serviceName}Exception" ); $client->addSubscriber(new ExceptionListener($exceptionFactory)); } // Add the UserAgentPlugin to append to the User-Agent header of requests $client->addSubscriber(new UserAgentListener()); // Filters used for the cache plugin $client->getConfig()->set( 'params.cache.key_filter', 'header=date,x-amz-date,x-amz-security-token,x-amzn-authorization' ); // Set the iterator resource factory based on the provided iterators config $client->setResourceIteratorFactory(new AwsResourceIteratorFactory( $this->iteratorsConfig, new ResourceIteratorClassFactory($this->clientNamespace . '\\Iterator') )); // Disable parameter validation if needed if ($config->get(Options::VALIDATION) === false) { $params = $config->get('command.params') ?: array(); $params['command.disable_validation'] = true; $config->set('command.params', $params); } return $client; } /** * Add backoff logging to the backoff plugin if needed * * @param BackoffPlugin $plugin Backoff plugin * @param Collection $config Configuration settings * * @throws InvalidArgumentException */ protected function addBackoffLogger(BackoffPlugin $plugin, Collection $config) { // The log option can be set to `debug` or an instance of a LogAdapterInterface if ($logger = $config->get(Options::BACKOFF_LOGGER)) { $format = $config->get(Options::BACKOFF_LOGGER_TEMPLATE); if ($logger === 'debug') { $logger = new ClosureLogAdapter(function ($message) { trigger_error($message . "\n"); }); } elseif (!($logger instanceof LogAdapterInterface)) { throw new InvalidArgumentException( Options::BACKOFF_LOGGER . ' must be set to `debug` or an instance of ' . 'Guzzle\\Common\\Log\\LogAdapterInterface' ); } // Create the plugin responsible for logging exponential backoff retries $logPlugin = new BackoffLogger($logger); // You can specify a custom format or use the default if ($format) { $logPlugin->setTemplate($format); } $plugin->addSubscriber($logPlugin); } } /** * Ensures that an array (e.g. for config data) is actually in array form * * @param array|Collection $array The array data * * @return array * @throws InvalidArgumentException if the arg is not an array or Collection */ protected function processArray($array) { if ($array instanceof Collection) { $array = $array->getAll(); } if (!is_array($array)) { throw new InvalidArgumentException('The config must be provided as an array or Collection.'); } return $array; } /** * Update a configuration object from a service description * * @param Collection $config Config to update * * @return ServiceDescription * @throws InvalidArgumentException */ protected function updateConfigFromDescription(Collection $config) { $description = $config->get(Options::SERVICE_DESCRIPTION); if (!($description instanceof ServiceDescription)) { // Inject the version into the sprintf template if it is a string if (is_string($description)) { $description = sprintf($description, $config->get(Options::VERSION)); } $description = ServiceDescription::factory($description); $config->set(Options::SERVICE_DESCRIPTION, $description); } if (!$config->get(Options::SERVICE)) { $config->set(Options::SERVICE, $description->getData('endpointPrefix')); } if ($iterators = $description->getData('iterators')) { $this->setIteratorsConfig($iterators); } // Ensure that the service description has regions if (!$description->getData('regions')) { throw new InvalidArgumentException( 'No regions found in the ' . $description->getData('serviceFullName'). ' description' ); } // Make sure a valid region is set $region = $config->get(Options::REGION); $global = $description->getData('globalEndpoint'); if (!$global && !$region) { throw new InvalidArgumentException( 'A region is required when using ' . $description->getData('serviceFullName') . '. Set "region" to one of: ' . implode(', ', array_keys($description->getData('regions'))) ); } elseif ($global && (!$region || $description->getData('namespace') !== 'S3')) { $region = Region::US_EAST_1; $config->set(Options::REGION, $region); } if (!$config->get(Options::BASE_URL)) { // Set the base URL using the scheme and hostname of the service's region $config->set(Options::BASE_URL, AbstractClient::getEndpoint( $description, $region, $config->get(Options::SCHEME) )); } return $description; } /** * Return an appropriate signature object for a a client based on the * "signature" configuration setting, or the default signature specified in * a service description. The signature can be set to a valid signature * version identifier string or an instance of Aws\Common\Signature\SignatureInterface. * * @param ServiceDescription $description Description that holds a signature option * @param Collection $config Configuration options * * @return SignatureInterface * @throws InvalidArgumentException */ protected function getSignature(ServiceDescription $description, Collection $config) { // If a custom signature has not been provided, then use the default // signature setting specified in the service description. $signature = $config->get(Options::SIGNATURE) ?: $description->getData('signatureVersion'); if (is_string($signature)) { if ($signature == 'v4') { $signature = new SignatureV4(); } elseif ($signature == 'v2') { $signature = new SignatureV2(); } elseif ($signature == 'v3https') { $signature = new SignatureV3Https(); } else { throw new InvalidArgumentException("Invalid signature type: {$signature}"); } } elseif (!($signature instanceof SignatureInterface)) { throw new InvalidArgumentException('The provided signature is not ' . 'a signature version string or an instance of ' . 'Aws\\Common\\Signature\\SignatureInterface'); } // Allow a custom service name or region value to be provided if ($signature instanceof EndpointSignatureInterface) { // Determine the service name to use when signing $signature->setServiceName($config->get(Options::SIGNATURE_SERVICE) ?: $description->getData('signingName') ?: $description->getData('endpointPrefix')); // Determine the region to use when signing requests $signature->setRegionName($config->get(Options::SIGNATURE_REGION) ?: $config->get(Options::REGION)); } return $signature; } } setConfig($config) ->setConfigDefaults(array(Options::SCHEME => 'https')) ->build(); } } true, 'ExpiredTokenException' => true, 'ExpiredToken' => true ); /** * @var ExceptionParserInterface Exception parser used to parse exception responses */ protected $exceptionParser; public function __construct(ExceptionParserInterface $exceptionParser, BackoffStrategyInterface $next = null) { $this->exceptionParser = $exceptionParser; $this->next = $next; } public function makesDecision() { return true; } protected function getDelay($retries, RequestInterface $request, Response $response = null, HttpException $e = null) { if ($response && $response->isClientError()) { $parts = $this->exceptionParser->parse($request, $response); if (!isset($this->retryable[$parts['code']]) || !$request->getClient()) { return null; } /** @var $client AwsClientInterface */ $client = $request->getClient(); // Only retry if the credentials can be refreshed if (!($client->getCredentials() instanceof AbstractRefreshableCredentials)) { return null; } // Resign the request using new credentials $client->getSignature()->signRequest($request, $client->getCredentials()->setExpiration(-1)); // Retry immediately with no delay return 0; } } } true, 'Throttling' => true, 'ThrottlingException' => true, 'ProvisionedThroughputExceededException' => true, 'RequestThrottled' => true, ); /** * @var ExceptionParserInterface Exception parser used to parse exception responses */ protected $exceptionParser; public function __construct(ExceptionParserInterface $exceptionParser, BackoffStrategyInterface $next = null) { $this->exceptionParser = $exceptionParser; if ($next) { $this->setNext($next); } } /** * {@inheritdoc} */ public function makesDecision() { return true; } /** * {@inheritdoc} */ protected function getDelay( $retries, RequestInterface $request, Response $response = null, HttpException $e = null ) { if ($response && $response->isClientError()) { $parts = $this->exceptionParser->parse($request, $response); return isset(self::$throttlingExceptions[$parts['code']]) ? true : null; } } } commands = $commands; $this->bodyParameter = (string) $bodyParameter; $this->sourceParameter = (string) $sourceParameter; } /** * {@inheritdoc} */ public static function getSubscribedEvents() { return array('command.before_prepare' => array('onCommandBeforePrepare')); } /** * Converts filenames and file handles into EntityBody objects before the command is validated * * @param Event $event Event emitted * @throws InvalidArgumentException */ public function onCommandBeforePrepare(Event $event) { /** @var $command Command */ $command = $event['command']; if (in_array($command->getName(), $this->commands)) { // Get the interesting parameters $source = $command->get($this->sourceParameter); $body = $command->get($this->bodyParameter); // If a file path is passed in then get the file handle if (is_string($source) && file_exists($source)) { $body = fopen($source, 'r'); } // Prepare the body parameter and remove the source file parameter if (null !== $body) { $command->remove($this->sourceParameter); $command->set($this->bodyParameter, EntityBody::factory($body)); } else { throw new InvalidArgumentException("You must specify a non-null value for the {$this->bodyParameter} or {$this->sourceParameter} parameters."); } } } } 'onBeforeSend'); } /** * Adds strings to the User-Agent header using the `ua.append` parameter of a command * * @param Event $event Event emitted */ public function onBeforeSend(Event $event) { $command = $event['command']; if ($userAgentAppends = $command->get(self::OPTION)) { $request = $command->getRequest(); $userAgent = (string) $request->getHeader('User-Agent'); foreach ((array) $userAgentAppends as $append) { $append = ' ' . $append; if (strpos($userAgent, $append) === false) { $userAgent .= $append; } } $request->setHeader('User-Agent', $userAgent); } } } customResolver($value, $param, $query, $param->getWireName()); $request->addPostFields($query); } /** * Map nested parameters into the location_key based parameters * * @param array $value Value to map * @param Parameter $param Parameter that holds information about the current key * @param array $query Built up query string values * @param string $prefix String to prepend to sub query values */ protected function customResolver($value, Parameter $param, array &$query, $prefix = '') { switch ($param->getType()) { case 'object': $this->resolveObject($param, $value, $prefix, $query); break; case 'array': $this->resolveArray($param, $value, $prefix, $query); break; default: $query[$prefix] = $param->filter($value); } } /** * Custom handling for objects * * @param Parameter $param Parameter for the object * @param array $value Value that is set for this parameter * @param string $prefix Prefix for the resulting key * @param array $query Query string array passed by reference */ protected function resolveObject(Parameter $param, array $value, $prefix, array &$query) { // Maps are implemented using additional properties $hasAdditionalProperties = ($param->getAdditionalProperties() instanceof Parameter); $additionalPropertyCount = 0; foreach ($value as $name => $v) { if ($subParam = $param->getProperty($name)) { // if the parameter was found by name as a regular property $key = $prefix . '.' . $subParam->getWireName(); $this->customResolver($v, $subParam, $query, $key); } elseif ($hasAdditionalProperties) { // Handle map cases like &Attribute.1.Name=&Attribute.1.Value= $additionalPropertyCount++; $data = $param->getData(); $keyName = isset($data['keyName']) ? $data['keyName'] : 'key'; $valueName = isset($data['valueName']) ? $data['valueName'] : 'value'; $query["{$prefix}.{$additionalPropertyCount}.{$keyName}"] = $name; $newPrefix = "{$prefix}.{$additionalPropertyCount}.{$valueName}"; if (is_array($v)) { $this->customResolver($v, $param->getAdditionalProperties(), $query, $newPrefix); } else { $query[$newPrefix] = $param->filter($v); } } } } /** * Custom handling for arrays * * @param Parameter $param Parameter for the object * @param array $value Value that is set for this parameter * @param string $prefix Prefix for the resulting key * @param array $query Query string array passed by reference */ protected function resolveArray(Parameter $param, array $value, $prefix, array &$query) { $offset = $param->getData('offset') ?: 1; foreach ($value as $index => $v) { $index += $offset; if (is_array($v) && $items = $param->getItems()) { $this->customResolver($v, $items, $query, $prefix . '.' . $index); } else { $query[$prefix . '.' . $index] = $param->filter($v); } } } } request->getBody()) { $this->request->setBody('{}'); } // Never send the Expect header when interacting with a JSON query service $this->request->removeHeader('Expect'); // Always send JSON requests as a raw string rather than using streams to avoid issues with // cURL error code 65: "necessary data rewind wasn't possible". // This could be removed after PHP addresses https://bugs.php.net/bug.php?id=47204 $this->request->getCurlOptions()->set(CurlHandle::BODY_AS_STRING, true); } } getRequestSerializer()->addVisitor('aws.query', self::$queryVisitor); $this->getResponseParser()->addVisitor('xml', self::$xmlVisitor); } } getOperation(); if ($operation->getServiceDescription()->getData('resultWrapped')) { $wrappingNode = $operation->getName() . 'Result'; if (isset($result[$wrappingNode])) { $result = $result[$wrappingNode] + $result; unset($result[$wrappingNode]); } } } /** * Accounts for wrapper nodes * {@inheritdoc} */ public function visit( CommandInterface $command, Response $response, Parameter $param, &$value, $context = null ) { parent::visit($command, $response, $param, $value, $context); // Account for wrapper nodes (e.g. RDS, ElastiCache, etc) if ($param->getData('wrapper')) { $wireName = $param->getWireName(); $value += $value[$wireName]; unset($value[$wireName]); } } /** * Filter used when converting XML maps into associative arrays in service descriptions * * @param array $value Value to filter * @param string $entryName Name of each entry * @param string $keyName Name of each key * @param string $valueName Name of each value * * @return array Returns the map of the XML data */ public static function xmlMap($value, $entryName, $keyName, $valueName) { $result = array(); foreach ($value as $entry) { $result[$entry[$keyName]] = $entry[$valueName]; } return $result; } } credentials = $credentials; } /** * {@inheritdoc} */ public function serialize() { return $this->credentials->serialize(); } /** * {@inheritdoc} */ public function unserialize($serialized) { $this->credentials = new Credentials('', ''); $this->credentials->unserialize($serialized); } /** * {@inheritdoc} */ public function getAccessKeyId() { return $this->credentials->getAccessKeyId(); } /** * {@inheritdoc} */ public function getSecretKey() { return $this->credentials->getSecretKey(); } /** * {@inheritdoc} */ public function getSecurityToken() { return $this->credentials->getSecurityToken(); } /** * {@inheritdoc} */ public function getExpiration() { return $this->credentials->getExpiration(); } /** * {@inheritdoc} */ public function isExpired() { return $this->credentials->isExpired(); } /** * {@inheritdoc} */ public function setAccessKeyId($key) { $this->credentials->setAccessKeyId($key); return $this; } /** * {@inheritdoc} */ public function setSecretKey($secret) { $this->credentials->setSecretKey($secret); return $this; } /** * {@inheritdoc} */ public function setSecurityToken($token) { $this->credentials->setSecurityToken($token); return $this; } /** * {@inheritdoc} */ public function setExpiration($timestamp) { $this->credentials->setExpiration($timestamp); return $this; } } credentials->isExpired()) { $this->refresh(); } return $this->credentials->getAccessKeyId(); } /** * {@inheritdoc} */ public function getSecretKey() { if ($this->credentials->isExpired()) { $this->refresh(); } return $this->credentials->getSecretKey(); } /** * {@inheritdoc} */ public function getSecurityToken() { if ($this->credentials->isExpired()) { $this->refresh(); } return $this->credentials->getSecurityToken(); } /** * {@inheritdoc} */ public function serialize() { if ($this->credentials->isExpired()) { $this->refresh(); } return $this->credentials->serialize(); } /** * Attempt to get new credentials */ abstract protected function refresh(); } credentials = $credentials; $this->cache = $cache; $this->cacheKey = $cacheKey; } /** * Attempt to get new credentials from cache or from the adapted object */ protected function refresh() { if (!$cache = $this->cache->fetch($this->cacheKey)) { // The credentials were not found, so try again and cache if new $this->credentials->getAccessKeyId(); if (!$this->credentials->isExpired()) { // The credentials were updated, so cache them $this->cache->save($this->cacheKey, $this->credentials, $this->credentials->getExpiration() - time()); } } else { // The credentials were found in cache, so update the adapter object // if the cached credentials are not expired if (!$cache->isExpired()) { $this->credentials->setAccessKeyId($cache->getAccessKeyId()); $this->credentials->setSecretKey($cache->getSecretKey()); $this->credentials->setSecurityToken($cache->getSecurityToken()); $this->credentials->setExpiration($cache->getExpiration()); } } } } null, Options::SECRET => null, Options::TOKEN => null, Options::TOKEN_TTD => null, Options::CREDENTIALS_CACHE => null, Options::CREDENTIALS_CACHE_KEY => null, Options::CREDENTIALS_CLIENT => null ); } /** * Factory method for creating new credentials. This factory method will * create the appropriate credentials object with appropriate decorators * based on the passed configuration options. * * @param array $config Options to use when instantiating the credentials * * @return CredentialsInterface * @throws InvalidArgumentException If the caching options are invalid * @throws RuntimeException If using the default cache and APC is disabled */ public static function factory($config = array()) { // Add default key values foreach (self::getConfigDefaults() as $key => $value) { if (!isset($config[$key])) { $config[$key] = $value; } } // Start tracking the cache key $cacheKey = $config[Options::CREDENTIALS_CACHE_KEY]; // Create the credentials object if (!$config[Options::KEY] || !$config[Options::SECRET]) { // No keys were provided, so attempt to retrieve some from the environment $envKey = isset($_SERVER[self::ENV_KEY]) ? $_SERVER[self::ENV_KEY] : getenv(self::ENV_KEY); $envSecret = isset($_SERVER[self::ENV_SECRET]) ? $_SERVER[self::ENV_SECRET] : getenv(self::ENV_SECRET); if ($envKey && $envSecret) { // Use credentials set in the environment variables $credentials = new static($envKey, $envSecret); } else { // Use instance profile credentials (available on EC2 instances) $credentials = new RefreshableInstanceProfileCredentials( new static('', '', '', 1), $config[Options::CREDENTIALS_CLIENT] ); } // If no cache key was set, use the crc32 hostname of the server $cacheKey = $cacheKey ?: 'credentials_' . crc32(gethostname()); } else { // Instantiate using short or long term credentials $credentials = new static( $config[Options::KEY], $config[Options::SECRET], $config[Options::TOKEN], $config[Options::TOKEN_TTD] ); // If no cache key was set, use the access key ID $cacheKey = $cacheKey ?: 'credentials_' . $config[Options::KEY]; } // Check if the credentials are refreshable, and if so, configure caching $cache = $config[Options::CREDENTIALS_CACHE]; if ($cacheKey && $cache) { if ($cache === 'true' || $cache === true) { // If no cache adapter was provided, then create one for the user // @codeCoverageIgnoreStart if (!extension_loaded('apc')) { throw new RequiredExtensionNotLoadedException('PHP has not been compiled with APC. Unable to cache ' . 'the credentials.'); } elseif (!class_exists('Doctrine\Common\Cache\ApcCache')) { throw new RuntimeException( 'Cannot set ' . Options::CREDENTIALS_CACHE . ' to true because the Doctrine cache component is ' . 'not installed. Either install doctrine/cache or pass in an instantiated ' . 'Guzzle\Cache\CacheAdapterInterface object' ); } // @codeCoverageIgnoreEnd $cache = new DoctrineCacheAdapter(new \Doctrine\Common\Cache\ApcCache()); } elseif (!($cache instanceof CacheAdapterInterface)) { throw new InvalidArgumentException('Unable to utilize caching with the specified options'); } // Decorate the credentials with a cache $credentials = new CacheableCredentials($credentials, $cache, $cacheKey); } return $credentials; } /** * Constructs a new BasicAWSCredentials object, with the specified AWS * access key and AWS secret key * * @param string $accessKeyId AWS access key ID * @param string $secretAccessKey AWS secret access key * @param string $token Security token to use * @param int $expiration UNIX timestamp for when credentials expire */ public function __construct($accessKeyId, $secretAccessKey, $token = null, $expiration = null) { $this->key = trim($accessKeyId); $this->secret = trim($secretAccessKey); $this->token = $token; $this->ttd = $expiration; } /** * {@inheritdoc} */ public function serialize() { return json_encode(array( Options::KEY => $this->key, Options::SECRET => $this->secret, Options::TOKEN => $this->token, Options::TOKEN_TTD => $this->ttd )); } /** * {@inheritdoc} */ public function unserialize($serialized) { $data = json_decode($serialized, true); $this->key = $data[Options::KEY]; $this->secret = $data[Options::SECRET]; $this->token = $data[Options::TOKEN]; $this->ttd = $data[Options::TOKEN_TTD]; } /** * {@inheritdoc} */ public function getAccessKeyId() { return $this->key; } /** * {@inheritdoc} */ public function getSecretKey() { return $this->secret; } /** * {@inheritdoc} */ public function getSecurityToken() { return $this->token; } /** * {@inheritdoc} */ public function getExpiration() { return $this->ttd; } /** * {@inheritdoc} */ public function isExpired() { return $this->ttd !== null && time() >= $this->ttd; } /** * {@inheritdoc} */ public function setAccessKeyId($key) { $this->key = $key; return $this; } /** * {@inheritdoc} */ public function setSecretKey($secret) { $this->secret = $secret; return $this; } /** * {@inheritdoc} */ public function setSecurityToken($token) { $this->token = $token; return $this; } /** * {@inheritdoc} */ public function setExpiration($timestamp) { $this->ttd = $timestamp; return $this; } } credentials = $credentials; $this->client = $client ?: InstanceMetadataClient::factory(); } /** * Attempt to get new credentials from the instance profile * * @throws InstanceProfileCredentialsException On error */ protected function refresh() { $credentials = $this->client->getInstanceProfileCredentials(); // Expire the token 1 minute before it actually expires to pre-fetch before expiring $this->credentials->setAccessKeyId($credentials->getAccessKeyId()) ->setSecretKey($credentials->getSecretKey()) ->setSecurityToken($credentials->getSecurityToken()) ->setExpiration($credentials->getExpiration()); } } getConstants(); } return self::$cache[$class]; } } factory = $factory; } /** * {@inheritdoc} */ public static function getSubscribedEvents() { return array('request.error' => array('onRequestError', -1)); } /** * Throws a more meaningful request exception if available * * @param Event $event Event emitted */ public function onRequestError(Event $event) { $e = $this->factory->fromResponse($event['request'], $event['response']); $event->stopPropagation(); throw $e; } } statusCode = $code; } /** * Get the error response code from the service * * @return string|null */ public function getStatusCode() { return $this->statusCode; } } getMessage(), 0, $exception ); $this->state = $state; } /** * Get the state of the transfer * * @return TransferStateInterface */ public function getState() { return $this->state; } } parser = $parser; $this->baseNamespace = $baseNamespace; $this->defaultException = $defaultException; } /** * {@inheritdoc} */ public function fromResponse(RequestInterface $request, Response $response) { $parts = $this->parser->parse($request, $response); // Removing leading 'AWS.' and embedded periods $className = $this->baseNamespace . '\\' . str_replace(array('AWS.', '.'), '', $parts['code']); if (substr($className, -9) !== 'Exception') { $className .= 'Exception'; } $className = class_exists($className) ? $className : $this->defaultException; return $this->createException($className, $request, $response, $parts); } /** * Create an prepare an exception object * * @param string $className Name of the class to create * @param RequestInterface $request Request * @param Response $response Response received * @param array $parts Parsed exception data * * @return \Exception */ protected function createException($className, RequestInterface $request, Response $response, array $parts) { $class = new $className($parts['message']); if ($class instanceof ServiceResponseException) { $class->setExceptionCode($parts['code']); $class->setExceptionType($parts['type']); $class->setResponse($response); $class->setRequest($request); $class->setRequestId($parts['request_id']); } return $class; } } null, 'message' => null, 'type' => $response->isClientError() ? 'client' : 'server', 'request_id' => (string) $response->getHeader('x-amzn-RequestId'), 'parsed' => null ); // Parse the json and normalize key casings if (null !== $json = json_decode($response->getBody(true), true)) { $data['parsed'] = array_change_key_case($json); } // Do additional, protocol-specific parsing and return the result $data = $this->doParse($data, $response); // Remove "Fault" suffix from exception names if (isset($data['code']) && strpos($data['code'], 'Fault')) { $data['code'] = preg_replace('/^([a-zA-Z]+)Fault$/', '$1', $data['code']); } return $data; } /** * Pull relevant exception data out of the parsed json * * @param array $data The exception data * @param Response $response The response from the service containing the error * * @return array */ abstract protected function doParse(array $data, Response $response); } null, 'message' => null, 'type' => $response->isClientError() ? 'client' : 'server', 'request_id' => null, 'parsed' => null ); if ($body = $response->getBody(true)) { $this->parseBody(new \SimpleXMLElement($body), $data); } else { $this->parseHeaders($request, $response, $data); } return $data; } /** * Parses additional exception information from the response headers * * @param RequestInterface $request Request that was issued * @param Response $response The response from the request * @param array $data The current set of exception data */ protected function parseHeaders(RequestInterface $request, Response $response, array &$data) { $data['message'] = $response->getStatusCode() . ' ' . $response->getReasonPhrase(); if ($requestId = $response->getHeader('x-amz-request-id')) { $data['request_id'] = $requestId; $data['message'] .= " (Request-ID: $requestId)"; } } /** * Parses additional exception information from the response body * * @param \SimpleXMLElement $body The response body as XML * @param array $data The current set of exception data */ protected function parseBody(\SimpleXMLElement $body, array &$data) { $data['parsed'] = $body; $namespaces = $body->getDocNamespaces(); if (isset($namespaces[''])) { // Account for the default namespace being defined and PHP not being able to handle it :( $body->registerXPathNamespace('ns', $namespaces['']); $prefix = 'ns:'; } else { $prefix = ''; } if ($tempXml = $body->xpath("//{$prefix}Code[1]")) { $data['code'] = (string) $tempXml[0]; } if ($tempXml = $body->xpath("//{$prefix}Message[1]")) { $data['message'] = (string) $tempXml[0]; } $tempXml = $body->xpath("//{$prefix}RequestId[1]"); if (empty($tempXml)) { $tempXml = $body->xpath("//{$prefix}RequestID[1]"); } if (isset($tempXml[0])) { $data['request_id'] = (string) $tempXml[0]; } } } getHeader('x-amzn-ErrorType')) { $data['code'] = substr($code, 0, strpos($code, ':')); } return $data; } } exceptionCode = $code; } /** * Get the exception code * * @return string|null */ public function getExceptionCode() { return $this->exceptionCode; } /** * Set the exception type * * @param string $type Exception type */ public function setExceptionType($type) { $this->exceptionType = $type; } /** * Get the exception type (one of client or server) * * @return string|null */ public function getExceptionType() { return $this->exceptionType; } /** * Set the request ID * * @param string $id Request ID */ public function setRequestId($id) { $this->requestId = $id; } /** * Get the Request ID * * @return string|null */ public function getRequestId() { return $this->requestId; } /** * Set the associated response * * @param Response $response Response */ public function setResponse(Response $response) { $this->response = $response; } /** * Get the associated response object * * @return Response|null */ public function getResponse() { return $this->response; } /** * Set the associated request * * @param RequestInterface $request */ public function setRequest(RequestInterface $request) { $this->request = $request; } /** * Get the associated request object * * @return RequestInterface|null */ public function getRequest() { return $this->request; } /** * Get the status code of the response * * @return int|null */ public function getStatusCode() { return $this->response ? $this->response->getStatusCode() : null; } /** * Cast to a string * * @return string */ public function __toString() { $message = get_class($this) . ': ' . 'AWS Error Code: ' . $this->getExceptionCode() . ', ' . 'Status Code: ' . $this->getStatusCode() . ', ' . 'AWS Request ID: ' . $this->getRequestId() . ', ' . 'AWS Error Type: ' . $this->getExceptionType() . ', ' . 'AWS Error Message: ' . $this->getMessage(); // Add the User-Agent if available if ($this->request) { $message .= ', ' . 'User-Agent: ' . $this->request->getHeader('User-Agent'); } return $message; } } getConfig() as $service) { if (isset($service['alias'], $service['class'])) { $facadeClass = __NAMESPACE__ . '\\' . $service['alias']; $facadeAlias = ltrim($targetNamespace . '\\' . $service['alias'], '\\'); if (!class_exists($facadeAlias)) { // @codeCoverageIgnoreStart class_alias($facadeClass, $facadeAlias); // @codeCoverageIgnoreEnd } } } } /** * Returns the instance of the client that the facade operates on * * @return \Aws\Common\Client\AwsClientInterface */ public static function getClient() { return self::$serviceBuilder->get(static::getServiceBuilderKey()); } public static function __callStatic($method, $args) { return call_user_func_array(array(self::getClient(), $method), $args); } } context = hash_init($algorithm); } /** * {@inheritdoc} */ public function addData($data) { if (!$this->context) { throw new LogicException('You may not add more data to a finalized chunk hash.'); } hash_update($this->context, $data); return $this; } /** * {@inheritdoc} */ public function getHash($returnBinaryForm = false) { if (!$this->hash) { $this->hashRaw = hash_final($this->context, true); $this->hash = HashUtils::binToHex($this->hashRaw); $this->context = null; } return $returnBinaryForm ? $this->hashRaw : $this->hash; } /** * {@inheritdoc} */ public function __clone() { if ($this->context) { $this->context = hash_copy($this->context); } } } checksums = $inBinaryForm ? $checksums : array_map('Aws\Common\Hash\HashUtils::hexToBin', $checksums); // Pre-calculate hash $treeHash->getHash(); return $treeHash; } /** * Create a tree hash from a content body * * @param string|resource|EntityBody $content Content to create a tree hash for * @param string $algorithm A valid hash algorithm name as returned by `hash_algos()` * * @return TreeHash */ public static function fromContent($content, $algorithm = self::DEFAULT_ALGORITHM) { $treeHash = new self($algorithm); // Read the data in 1MB chunks and add to tree hash $content = EntityBody::factory($content); while ($data = $content->read(Size::MB)) { $treeHash->addData($data); } // Pre-calculate hash $treeHash->getHash(); return $treeHash; } /** * Validates an entity body with a tree hash checksum * * @param string|resource|EntityBody $content Content to create a tree hash for * @param string $checksum The checksum to use for validation * @param string $algorithm A valid hash algorithm name as returned by `hash_algos()` * * @return bool */ public static function validateChecksum($content, $checksum, $algorithm = self::DEFAULT_ALGORITHM) { $treeHash = self::fromContent($content, $algorithm); return ($checksum === $treeHash->getHash()); } /** * {@inheritdoc} */ public function __construct($algorithm = self::DEFAULT_ALGORITHM) { HashUtils::validateAlgorithm($algorithm); $this->algorithm = $algorithm; } /** * {@inheritdoc} * @throws LogicException if the root tree hash is already calculated * @throws InvalidArgumentException if the data is larger than 1MB */ public function addData($data) { // Error if hash is already calculated if ($this->hash) { throw new LogicException('You may not add more data to a finalized tree hash.'); } // Make sure that only 1MB chunks or smaller get passed in if (strlen($data) > Size::MB) { throw new InvalidArgumentException('The chunk of data added is too large for tree hashing.'); } // Store the raw hash of this data segment $this->checksums[] = hash($this->algorithm, $data, true); return $this; } /** * Add a checksum to the tree hash directly * * @param string $checksum The checksum to add * @param bool $inBinaryForm Whether or not the checksum is already in binary form * * @return self * @throws LogicException if the root tree hash is already calculated */ public function addChecksum($checksum, $inBinaryForm = false) { // Error if hash is already calculated if ($this->hash) { throw new LogicException('You may not add more checksums to a finalized tree hash.'); } // Convert the checksum to binary form if necessary $this->checksums[] = $inBinaryForm ? $checksum : HashUtils::hexToBin($checksum); return $this; } /** * {@inheritdoc} */ public function getHash($returnBinaryForm = false) { if (!$this->hash) { // Perform hashes up the tree to arrive at the root checksum of the tree hash $hashes = $this->checksums; while (count($hashes) > 1) { $sets = array_chunk($hashes, 2); $hashes = array(); foreach ($sets as $set) { $hashes[] = (count($set) === 1) ? $set[0] : hash($this->algorithm, $set[0] . $set[1], true); } } $this->hashRaw = $hashes[0]; $this->hash = HashUtils::binToHex($this->hashRaw); } return $returnBinaryForm ? $this->hashRaw : $this->hash; } /** * @return array Array of raw checksums composing the tree hash */ public function getChecksums() { return $this->checksums; } } getHost(), -14) != '.amazonaws.com') { return self::DEFAULT_REGION; } $serviceAndRegion = substr($url->getHost(), 0, -14); // Special handling for S3 regions $separator = strpos($serviceAndRegion, 's3') === 0 ? '-' : '.'; $separatorPos = strpos($serviceAndRegion, $separator); // If don't detect a separator, then return the default region if ($separatorPos === false) { return self::DEFAULT_REGION; } $region = substr($serviceAndRegion, $separatorPos + 1); // All GOV regions currently use the default GOV region if ($region == 'us-gov') { return self::DEFAULT_GOV_REGION; } return $region; } /** * Parse the AWS service name from a URL * * @param Url $url HTTP URL * * @return string Returns a service name (or empty string) * @link http://docs.aws.amazon.com/general/latest/gr/rande.html */ public static function parseServiceName(Url $url) { // The service name is the first part of the host $parts = explode('.', $url->getHost(), 2); // Special handling for S3 if (stripos($parts[0], 's3') === 0) { return 's3'; } return $parts[0]; } } 'http://169.254.169.254/{version}/', 'version' => 'latest', 'request.options' => array( 'connect_timeout' => 5, 'timeout' => 10 ) ), array('base_url', 'version')); return new self($config); } /** * Constructor override */ public function __construct(Collection $config) { $this->setConfig($config); $this->setBaseUrl($config->get(Options::BASE_URL)); $this->defaultHeaders = new Collection(); $this->setRequestFactory(RequestFactory::getInstance()); } /** * Get instance profile credentials * * @return Credentials * @throws InstanceProfileCredentialsException */ public function getInstanceProfileCredentials() { try { $request = $this->get('meta-data/iam/security-credentials/'); $credentials = trim($request->send()->getBody(true)); $result = $this->get("meta-data/iam/security-credentials/{$credentials}")->send()->json(); } catch (\Exception $e) { $message = sprintf('Error retrieving credentials from the instance profile metadata server. When you are' . ' not running inside of Amazon EC2, you must provide your AWS access key ID and secret access key in' . ' the "key" and "secret" options when creating a client or provide an instantiated' . ' Aws\\Common\\Credentials\\CredentialsInterface object. (%s)', $e->getMessage()); throw new InstanceProfileCredentialsException($message, $e->getCode()); } // Ensure that the status code was successful if ($result['Code'] !== 'Success') { $e = new InstanceProfileCredentialsException('Unexpected response code: ' . $result['Code']); $e->setStatusCode($result['Code']); throw $e; } return new Credentials( $result['AccessKeyId'], $result['SecretAccessKey'], $result['Token'], strtotime($result['Expiration']) ); } } client->get(); try { $request->getCurlOptions()->set(CURLOPT_CONNECTTIMEOUT, 10) ->set(CURLOPT_TIMEOUT, 10); $request->send(); return true; } catch (CurlException $e) { return false; } } } lastResult; } /** * {@inheritdoc} * This AWS specific version of the resource iterator provides a default implementation of the typical AWS iterator * process. It relies on configuration and extension to implement the operation-specific logic of handling results * and nextTokens. This method will loop until resources are acquired or there are no more iterations available. */ protected function sendRequest() { do { // Prepare the request including setting the next token $this->prepareRequest(); if ($this->nextToken) { $this->applyNextToken(); } // Execute the request and handle the results $this->command->add(Ua::OPTION, Ua::ITERATOR); $this->lastResult = $this->command->getResult(); $resources = $this->handleResults($this->lastResult); $this->determineNextToken($this->lastResult); // If no resources collected, prepare to reiterate before yielding if ($reiterate = empty($resources) && $this->nextToken) { $this->command = clone $this->originalCommand; } } while ($reiterate); return $resources; } /** * {@inheritdoc} */ protected function prepareRequest() { // Get the limit parameter key to set $param = $this->get('limit_param'); if ($param && ($limit = $this->command->get($param))) { $pageSize = $this->calculatePageSize(); // If the limit of the command is different than the pageSize of the iterator, use the smaller value if ($limit && $pageSize) { $this->command->set('limit', min($limit, $pageSize)); } } } /** * {@inheritdoc} */ protected function handleResults(Model $result) { $results = array(); // Get the result key that contains the results if ($resultKey = $this->get('result_key')) { $results = $result->getPath($resultKey) ?: array(); } return $results; } /** * {@inheritdoc} */ protected function applyNextToken() { // Get the token parameter key to set if ($tokenParam = $this->get('token_param')) { // Set the next token. Works with multi-value tokens if (is_array($tokenParam)) { if (is_array($this->nextToken) && count($tokenParam) === count($this->nextToken)) { foreach (array_combine($tokenParam, $this->nextToken) as $param => $token) { $this->command->set($param, $token); } } else { throw new RuntimeException('The definition of the iterator\'s token parameter and the actual token ' . 'value are not compatible.'); } } else { $this->command->set($tokenParam, $this->nextToken); } } } /** * {@inheritdoc} */ protected function determineNextToken(Model $result) { $this->nextToken = null; // If the value of "more key" is true or there is no "more key" to check, then try to get the next token $moreKey = $this->get('more_key'); if ($moreKey === null || $result->getPath($moreKey)) { // Get the token key to check if ($tokenKey = $this->get('token_key')) { // Get the next token's value. Works with multi-value tokens $getToken = function ($key) use ($result) { return $result->getPath((string) $key); }; $this->nextToken = is_array($tokenKey) ? array_map($getToken, $tokenKey) : $getToken($tokenKey); } } } } null, 'limit_param' => null, 'more_key' => null, 'token_key' => null, 'token_param' => null, 'operations' => array(), ); /** * @var Collection The configuration for the iterators */ protected $config; /** * @var Collection Additional configurations for specific iterators */ protected $operations; /** * @var ResourceIteratorFactoryInterface Another factory that will be used first to instantiate the iterator */ protected $primaryIteratorFactory; /** * @param array $config An array of configuration values for the factory * @param ResourceIteratorFactoryInterface $primaryIteratorFactory Another factory to use for chain of command * * @throws InvalidArgumentException */ public function __construct(array $config, ResourceIteratorFactoryInterface $primaryIteratorFactory = null) { $this->primaryIteratorFactory = $primaryIteratorFactory; // Set up the config with default values $this->config = Collection::fromConfig($config, self::$defaultConfig); // Pull out the operation-specific configurations $this->operations = new Collection(); $potentialOperations = $this->config->get('operations') ?: array(); $this->config->remove('operations'); foreach ($potentialOperations as $key => $value) { if (is_int($key) && is_string($value)) { $this->operations->set($value, array()); } elseif (is_string($key) && is_array($value)) { $this->operations->set($key, $value); } else { throw new InvalidArgumentException('The iterator factory configuration was invalid.'); } } } /** * {@inheritdoc} */ public function build(CommandInterface $command, array $options = array()) { // Get the configuration data for the command $commandName = $command->getName(); $iteratorConfig = $this->operations->get($commandName) ?: array(); $options = array_replace($this->config->getAll(), $iteratorConfig, $options); // Instantiate the iterator using the primary factory (if there is one) if ($this->primaryIteratorFactory && $this->primaryIteratorFactory->canBuild($command)) { $iterator = $this->primaryIteratorFactory->build($command, $options); } elseif (!$this->operations->hasKey($commandName)) { throw new InvalidArgumentException("Iterator was not found for {$commandName}."); } else { // Fallback to this factory for creating the iterator if the primary factory did not work $iterator = new AwsResourceIterator($command, $options); } return $iterator; } /** * {@inheritdoc} */ public function canBuild(CommandInterface $command) { return ($this->primaryIteratorFactory && $this->primaryIteratorFactory->canBuild($command)) || $this->operations->hasKey($command->getName()); } } client = $client; $this->state = $state; $this->source = $source; $this->options = $options; $this->init(); $this->partSize = $this->calculatePartSize(); } public function __invoke() { return $this->upload(); } /** * {@inheritdoc} */ public static function getAllEvents() { return array( self::BEFORE_PART_UPLOAD, self::AFTER_UPLOAD, self::BEFORE_PART_UPLOAD, self::AFTER_PART_UPLOAD, self::AFTER_ABORT, self::AFTER_COMPLETE ); } /** * {@inheritdoc} */ public function abort() { $command = $this->getAbortCommand(); $result = $command->getResult(); $this->state->setAborted(true); $this->stop(); $this->dispatch(self::AFTER_ABORT, $this->getEventData($command)); return $result; } /** * {@inheritdoc} */ public function stop() { $this->stopped = true; return $this->state; } /** * {@inheritdoc} */ public function getState() { return $this->state; } /** * Get the array of options associated with the transfer * * @return array */ public function getOptions() { return $this->options; } /** * Set an option on the transfer * * @param string $option Name of the option * @param mixed $value Value to set * * @return self */ public function setOption($option, $value) { $this->options[$option] = $value; return $this; } /** * Get the source body of the upload * * @return EntityBodyInterface */ public function getSource() { return $this->source; } /** * {@inheritdoc} * @throws MultipartUploadException when an error is encountered. Use getLastException() to get more information. * @throws RuntimeException when attempting to upload an aborted transfer */ public function upload() { if ($this->state->isAborted()) { throw new RuntimeException('The transfer has been aborted and cannot be uploaded'); } $this->stopped = false; $eventData = $this->getEventData(); $this->dispatch(self::BEFORE_UPLOAD, $eventData); try { $this->transfer(); $this->dispatch(self::AFTER_UPLOAD, $eventData); if ($this->stopped) { return null; } else { $result = $this->complete(); $this->dispatch(self::AFTER_COMPLETE, $eventData); } } catch (\Exception $e) { throw new MultipartUploadException($this->state, $e); } return $result; } /** * Get an array used for event notifications * * @param OperationCommand $command Command to include in event data * * @return array */ protected function getEventData(OperationCommand $command = null) { $data = array( 'transfer' => $this, 'source' => $this->source, 'options' => $this->options, 'client' => $this->client, 'part_size' => $this->partSize, 'state' => $this->state ); if ($command) { $data['command'] = $command; } return $data; } /** * Hook to initialize the transfer */ protected function init() {} /** * Determine the upload part size based on the size of the source data and * taking into account the acceptable minimum and maximum part sizes. * * @return int The part size */ abstract protected function calculatePartSize(); /** * Complete the multipart upload * * @return Model Returns the result of the complete multipart upload command */ abstract protected function complete(); /** * Hook to implement in subclasses to perform the actual transfer */ abstract protected function transfer(); /** * Fetches the abort command fom the concrete implementation * * @return OperationCommand */ abstract protected function getAbortCommand(); } uploadId = $uploadId; } /** * {@inheritdoc} */ public function getUploadId() { return $this->uploadId; } /** * Get a data value from the transfer state's uploadId * * @param string $key Key to retrieve (e.g. Bucket, Key, UploadId, etc) * * @return string|null */ public function getFromId($key) { $params = $this->uploadId->toParams(); return isset($params[$key]) ? $params[$key] : null; } /** * {@inheritdoc} */ public function getPart($partNumber) { return isset($this->parts[$partNumber]) ? $this->parts[$partNumber] : null; } /** * {@inheritdoc} */ public function addPart(UploadPartInterface $part) { $partNumber = $part->getPartNumber(); $this->parts[$partNumber] = $part; return $this; } /** * {@inheritdoc} */ public function hasPart($partNumber) { return isset($this->parts[$partNumber]); } /** * {@inheritdoc} */ public function getPartNumbers() { return array_keys($this->parts); } /** * {@inheritdoc} */ public function setAborted($aborted) { $this->aborted = (bool) $aborted; return $this; } /** * {@inheritdoc} */ public function isAborted() { return $this->aborted; } /** * {@inheritdoc} */ public function count() { return count($this->parts); } /** * {@inheritdoc} */ public function getIterator() { return new \ArrayIterator($this->parts); } /** * {@inheritdoc} */ public function serialize() { return serialize(get_object_vars($this)); } /** * {@inheritdoc} */ public function unserialize($serialized) { $data = unserialize($serialized); foreach (get_object_vars($this) as $property => $oldValue) { if (array_key_exists($property, $data)) { $this->{$property} = $data[$property]; } else { throw new RuntimeException("The {$property} property could be restored during unserialization."); } } } } client = $client; return $this; } /** * Set the state of the upload. This is useful for resuming from a previously started multipart upload. * You must use a local file stream as the data source if you wish to resume from a previous upload. * * @param TransferStateInterface|string $state Pass a TransferStateInterface object or the ID of the initiated * multipart upload. When an ID is passed, the builder will create a * state object using the data from a ListParts API response. * * @return self */ public function resumeFrom($state) { $this->state = $state; return $this; } /** * Set the data source of the transfer * * @param resource|string|EntityBody $source Source of the transfer. Pass a string to transfer from a file on disk. * You can also stream from a resource returned from fopen or a Guzzle * {@see EntityBody} object. * * @return self * @throws InvalidArgumentException when the source cannot be found or opened */ public function setSource($source) { // Use the contents of a file as the data source if (is_string($source)) { if (!file_exists($source)) { throw new InvalidArgumentException("File does not exist: {$source}"); } // Clear the cache so that we send accurate file sizes clearstatcache(true, $source); $source = fopen($source, 'r'); } $this->source = EntityBody::factory($source); if ($this->source->isSeekable() && $this->source->getSize() == 0) { throw new InvalidArgumentException('Empty body provided to upload builder'); } return $this; } /** * Specify the headers to set on the upload * * @param array $headers Headers to add to the uploaded object * * @return self */ public function setHeaders(array $headers) { $this->headers = $headers; return $this; } /** * Build the appropriate uploader based on the builder options * * @return TransferInterface */ abstract public function build(); /** * Initiate the multipart upload * * @return TransferStateInterface */ abstract protected function initiateMultipartUpload(); } loadData($data); return $uploadId; } /** * {@inheritdoc} */ public function toParams() { return $this->data; } /** * {@inheritdoc} */ public function serialize() { return serialize($this->data); } /** * {@inheritdoc} */ public function unserialize($serialized) { $this->loadData(unserialize($serialized)); } /** * Loads an array of data into the UploadId by extracting only the needed keys * * @param array $data Data to load * * @throws InvalidArgumentException if a required key is missing */ protected function loadData($data) { $data = array_replace(static::$expectedValues, array_intersect_key($data, static::$expectedValues)); foreach ($data as $key => $value) { if (isset($data[$key])) { $this->data[$key] = $data[$key]; } else { throw new InvalidArgumentException("A required key [$key] was missing from the UploadId."); } } } } loadData($data); return $part; } /** * {@inheritdoc} */ public function getPartNumber() { return $this->partNumber; } /** * {@inheritdoc} */ public function toArray() { $array = array(); foreach (static::$keyMap as $key => $property) { $array[$key] = $this->{$property}; } return $array; } /** * {@inheritdoc} */ public function serialize() { return serialize($this->toArray()); } /** * {@inheritdoc} */ public function unserialize($serialized) { $this->loadData(unserialize($serialized)); } /** * Loads an array of data into the upload part by extracting only the needed keys * * @param array|\Traversable $data Data to load into the upload part value object * * @throws InvalidArgumentException if a required key is missing */ protected function loadData($data) { foreach (static::$keyMap as $key => $property) { if (isset($data[$key])) { $this->{$property} = $data[$key]; } else { throw new InvalidArgumentException("A required key [$key] was missing from the upload part."); } } } } 'Aws\Common\Aws', 'services' => array( 'default_settings' => array( 'params' => array() ), 'autoscaling' => array( 'alias' => 'AutoScaling', 'extends' => 'default_settings', 'class' => 'Aws\AutoScaling\AutoScalingClient' ), 'cloudformation' => array( 'alias' => 'CloudFormation', 'extends' => 'default_settings', 'class' => 'Aws\CloudFormation\CloudFormationClient' ), 'cloudfront' => array( 'alias' => 'CloudFront', 'extends' => 'default_settings', 'class' => 'Aws\CloudFront\CloudFrontClient' ), 'cloudfront_20120505' => array( 'extends' => 'cloudfront', 'params' => array( 'version' => '2012-05-05' ) ), 'cloudsearch' => array( 'alias' => 'CloudSearch', 'extends' => 'default_settings', 'class' => 'Aws\CloudSearch\CloudSearchClient' ), 'cloudtrail' => array( 'alias' => 'CloudTrail', 'extends' => 'default_settings', 'class' => 'Aws\CloudTrail\CloudTrailClient' ), 'cloudwatch' => array( 'alias' => 'CloudWatch', 'extends' => 'default_settings', 'class' => 'Aws\CloudWatch\CloudWatchClient' ), 'datapipeline' => array( 'alias' => 'DataPipeline', 'extends' => 'default_settings', 'class' => 'Aws\DataPipeline\DataPipelineClient' ), 'directconnect' => array( 'alias' => 'DirectConnect', 'extends' => 'default_settings', 'class' => 'Aws\DirectConnect\DirectConnectClient' ), 'dynamodb' => array( 'alias' => 'DynamoDb', 'extends' => 'default_settings', 'class' => 'Aws\DynamoDb\DynamoDbClient' ), 'dynamodb_20111205' => array( 'extends' => 'dynamodb', 'params' => array( 'version' => '2011-12-05' ) ), 'ec2' => array( 'alias' => 'Ec2', 'extends' => 'default_settings', 'class' => 'Aws\Ec2\Ec2Client' ), 'elasticache' => array( 'alias' => 'ElastiCache', 'extends' => 'default_settings', 'class' => 'Aws\ElastiCache\ElastiCacheClient' ), 'elasticbeanstalk' => array( 'alias' => 'ElasticBeanstalk', 'extends' => 'default_settings', 'class' => 'Aws\ElasticBeanstalk\ElasticBeanstalkClient' ), 'elasticloadbalancing' => array( 'alias' => 'ElasticLoadBalancing', 'extends' => 'default_settings', 'class' => 'Aws\ElasticLoadBalancing\ElasticLoadBalancingClient' ), 'elastictranscoder' => array( 'alias' => 'ElasticTranscoder', 'extends' => 'default_settings', 'class' => 'Aws\ElasticTranscoder\ElasticTranscoderClient' ), 'emr' => array( 'alias' => 'Emr', 'extends' => 'default_settings', 'class' => 'Aws\Emr\EmrClient' ), 'glacier' => array( 'alias' => 'Glacier', 'extends' => 'default_settings', 'class' => 'Aws\Glacier\GlacierClient' ), 'kinesis' => array( 'alias' => 'Kinesis', 'extends' => 'default_settings', 'class' => 'Aws\Kinesis\KinesisClient' ), 'iam' => array( 'alias' => 'Iam', 'extends' => 'default_settings', 'class' => 'Aws\Iam\IamClient' ), 'importexport' => array( 'alias' => 'ImportExport', 'extends' => 'default_settings', 'class' => 'Aws\ImportExport\ImportExportClient' ), 'opsworks' => array( 'alias' => 'OpsWorks', 'extends' => 'default_settings', 'class' => 'Aws\OpsWorks\OpsWorksClient' ), 'rds' => array( 'alias' => 'Rds', 'extends' => 'default_settings', 'class' => 'Aws\Rds\RdsClient' ), 'redshift' => array( 'alias' => 'Redshift', 'extends' => 'default_settings', 'class' => 'Aws\Redshift\RedshiftClient' ), 'route53' => array( 'alias' => 'Route53', 'extends' => 'default_settings', 'class' => 'Aws\Route53\Route53Client' ), 's3' => array( 'alias' => 'S3', 'extends' => 'default_settings', 'class' => 'Aws\S3\S3Client' ), 'sdb' => array( 'alias' => 'SimpleDb', 'extends' => 'default_settings', 'class' => 'Aws\SimpleDb\SimpleDbClient' ), 'ses' => array( 'alias' => 'Ses', 'extends' => 'default_settings', 'class' => 'Aws\Ses\SesClient' ), 'sns' => array( 'alias' => 'Sns', 'extends' => 'default_settings', 'class' => 'Aws\Sns\SnsClient' ), 'sqs' => array( 'alias' => 'Sqs', 'extends' => 'default_settings', 'class' => 'Aws\Sqs\SqsClient' ), 'storagegateway' => array( 'alias' => 'StorageGateway', 'extends' => 'default_settings', 'class' => 'Aws\StorageGateway\StorageGatewayClient' ), 'sts' => array( 'alias' => 'Sts', 'extends' => 'default_settings', 'class' => 'Aws\Sts\StsClient' ), 'support' => array( 'alias' => 'Support', 'extends' => 'default_settings', 'class' => 'Aws\Support\SupportClient' ), 'swf' => array( 'alias' => 'Swf', 'extends' => 'default_settings', 'class' => 'Aws\Swf\SwfClient' ), ) ); array('_aws'), 'services' => array( 'sdk1_settings' => array( 'extends' => 'default_settings', 'params' => array( 'certificate_authority' => false ) ), 'v1.autoscaling' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonAS' ), 'v1.cloudformation' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonCloudFormation' ), 'v1.cloudfront' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonCloudFront' ), 'v1.cloudsearch' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonCloudSearch' ), 'v1.cloudwatch' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonCloudWatch' ), 'v1.dynamodb' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonDynamoDB' ), 'v1.ec2' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonEC2' ), 'v1.elasticache' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonElastiCache' ), 'v1.elasticbeanstalk' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonElasticBeanstalk' ), 'v1.elb' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonELB' ), 'v1.emr' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonEMR' ), 'v1.iam' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonIAM' ), 'v1.importexport' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonImportExport' ), 'v1.rds' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonRDS' ), 'v1.s3' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonS3' ), 'v1.sdb' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSDB' ), 'v1.ses' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSES' ), 'v1.sns' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSNS' ), 'v1.sqs' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSQS' ), 'v1.storagegateway' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonStorageGateway' ), 'v1.sts' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSTS' ), 'v1.swf' => array( 'extends' => 'sdk1_settings', 'class' => 'AmazonSWF' ) ) ); credentials = $credentials; $this->signature = $signature; } /** * {@inheritdoc} */ public static function getSubscribedEvents() { return array( 'request.before_send' => array('onRequestBeforeSend', -255), 'client.credentials_changed' => array('onCredentialsChanged') ); } /** * Updates the listener with new credentials if the client is updated * * @param Event $event Event emitted */ public function onCredentialsChanged(Event $event) { $this->credentials = $event['credentials']; } /** * Signs requests before they are sent * * @param Event $event Event emitted */ public function onRequestBeforeSend(Event $event) { $this->signature->signRequest($event['request'], $this->credentials); } } getTimestamp(true); // set values we need in CanonicalizedParameterString $this->addParameter($request, 'Timestamp', gmdate('c', $timestamp)); $this->addParameter($request, 'SignatureVersion', '2'); $this->addParameter($request, 'SignatureMethod', 'HmacSHA256'); $this->addParameter($request, 'AWSAccessKeyId', $credentials->getAccessKeyId()); if ($token = $credentials->getSecurityToken()) { $this->addParameter($request, 'SecurityToken', $token); } // Get the path and ensure it's absolute $path = '/' . ltrim($request->getUrl(true)->normalizePath()->getPath(), '/'); // build string to sign $sign = $request->getMethod() . "\n" . $request->getHost() . "\n" . $path . "\n" . $this->getCanonicalizedParameterString($request); // Add the string to sign to the request for debugging purposes $request->getParams()->set('aws.string_to_sign', $sign); $signature = base64_encode( hash_hmac( 'sha256', $sign, $credentials->getSecretKey(), true ) ); $this->addParameter($request, 'Signature', $signature); } /** * Add a parameter key and value to the request according to type * * @param RequestInterface $request The request * @param string $key The name of the parameter * @param string $value The value of the parameter */ public function addParameter(RequestInterface $request, $key, $value) { if ($request->getMethod() == 'POST') { $request->setPostField($key, $value); } else { $request->getQuery()->set($key, $value); } } /** * Get the canonicalized query/parameter string for a request * * @param RequestInterface $request Request used to build canonicalized string * * @return string */ private function getCanonicalizedParameterString(RequestInterface $request) { if ($request->getMethod() == 'POST') { $params = $request->getPostFields()->toArray(); } else { $params = $request->getQuery()->toArray(); } // Don't resign a previous signature value unset($params['Signature']); uksort($params, 'strcmp'); $str = ''; foreach ($params as $key => $val) { $str .= rawurlencode($key) . '=' . rawurlencode($val) . '&'; } return substr($str, 0, -1); } } hasHeader('date') && !$request->hasHeader('x-amz-date')) { $request->setHeader('Date', gmdate(DateFormat::RFC1123, $this->getTimestamp())); } // Add the security token if one is present if ($credentials->getSecurityToken()) { $request->setHeader('x-amz-security-token', $credentials->getSecurityToken()); } // Determine the string to sign $stringToSign = (string) ($request->getHeader('Date') ?: $request->getHeader('x-amz-date')); $request->getParams()->set('aws.string_to_sign', $stringToSign); // Calculate the signature $signature = base64_encode(hash_hmac('sha256', $stringToSign, $credentials->getSecretKey(), true)); // Add the authorization header to the request $headerFormat = 'AWS3-HTTPS AWSAccessKeyId=%s,Algorithm=HmacSHA256,Signature=%s'; $request->setHeader('X-Amzn-Authorization', sprintf($headerFormat, $credentials->getAccessKeyId(), $signature)); } } serviceName = $serviceName; $this->regionName = $regionName; } /** * Set the service name instead of inferring it from a request URL * * @param string $service Name of the service used when signing * * @return self */ public function setServiceName($service) { $this->serviceName = $service; return $this; } /** * Set the region name instead of inferring it from a request URL * * @param string $region Name of the region used when signing * * @return self */ public function setRegionName($region) { $this->regionName = $region; return $this; } /** * Set the maximum number of computed hashes to cache * * @param int $maxCacheSize Maximum number of hashes to cache * * @return self */ public function setMaxCacheSize($maxCacheSize) { $this->maxCacheSize = $maxCacheSize; return $this; } public function signRequest(RequestInterface $request, CredentialsInterface $credentials) { $timestamp = $this->getTimestamp(); $longDate = gmdate(DateFormat::ISO8601, $timestamp); $shortDate = substr($longDate, 0, 8); // Remove any previously set Authorization headers so that retries work $request->removeHeader('Authorization'); // Requires a x-amz-date header or Date if ($request->hasHeader('x-amz-date') || !$request->hasHeader('Date')) { $request->setHeader('x-amz-date', $longDate); } else { $request->setHeader('Date', gmdate(DateFormat::RFC1123, $timestamp)); } // Add the security token if one is present if ($credentials->getSecurityToken()) { $request->setHeader('x-amz-security-token', $credentials->getSecurityToken()); } // Parse the service and region or use one that is explicitly set $region = $this->regionName; $service = $this->serviceName; if (!$region || !$service) { $url = Url::factory($request->getUrl()); $region = $region ?: HostNameUtils::parseRegionName($url); $service = $service ?: HostNameUtils::parseServiceName($url); } $credentialScope = "{$shortDate}/{$region}/{$service}/aws4_request"; // Calculate the request signature payload if ($request->hasHeader('x-amz-content-sha256')) { // Handle streaming operations (e.g. Glacier.UploadArchive) $payload = $request->getHeader('x-amz-content-sha256'); } elseif ($request instanceof EntityEnclosingRequestInterface) { $payload = hash( 'sha256', $request->getMethod() == 'POST' && count($request->getPostFields()) ? (string) $request->getPostFields() : (string) $request->getBody() ); } else { // Use the default payload if there is no body $payload = self::DEFAULT_PAYLOAD; } $signingContext = $this->createSigningContext($request, $payload); $signingContext['string_to_sign'] = "AWS4-HMAC-SHA256\n{$longDate}\n{$credentialScope}\n" . hash('sha256', $signingContext['canonical_request']); // Calculate the signing key using a series of derived keys $signingKey = $this->getSigningKey($shortDate, $region, $service, $credentials->getSecretKey()); $signature = hash_hmac('sha256', $signingContext['string_to_sign'], $signingKey); $request->setHeader('Authorization', "AWS4-HMAC-SHA256 " . "Credential={$credentials->getAccessKeyId()}/{$credentialScope}, " . "SignedHeaders={$signingContext['signed_headers']}, Signature={$signature}"); // Add debug information to the request $request->getParams()->set('aws.signature', $signingContext); } /** * Create the canonical representation of a request * * @param RequestInterface $request Request to canonicalize * @param string $payload Request payload (typically the value * of the x-amz-content-sha256 header. * * @return array Returns an array of context information including: * - canonical_request * - signed_headers */ protected function createSigningContext(RequestInterface $request, $payload) { // Normalize the path as required by SigV4 and ensure it's absolute $canon = $request->getMethod() . "\n" . $this->normalizePath($request) . "\n" . $this->getCanonicalizedQueryString($request) . "\n"; // Create the canonical headers $headers = array(); foreach ($request->getHeaders()->getAll() as $key => $values) { $key = strtolower($key); if ($key != 'user-agent') { $headers[$key] = array(); foreach ($values as $value) { $headers[$key][] = preg_replace('/\s+/', ' ', trim($value)); } // Sort the value if there is more than one if (count($values) > 1) { sort($headers[$key]); } } } // The headers must be sorted ksort($headers); // Continue to build the canonical request by adding headers foreach ($headers as $key => $values) { // Combine multi-value headers into a comma separated list $canon .= $key . ':' . implode(',', $values) . "\n"; } // Create the signed headers $signedHeaders = implode(';', array_keys($headers)); $canon .= "\n{$signedHeaders}\n{$payload}"; return array( 'canonical_request' => $canon, 'signed_headers' => $signedHeaders ); } /** * Get the normalized path of a request * * @param RequestInterface $request Request to normalize * * @return string Returns the normalized path */ protected function normalizePath(RequestInterface $request) { return '/' . ltrim($request->getUrl(true)->normalizePath()->getPath(), '/'); } /** * Get a hash for a specific key and value. If the hash was previously * cached, return it * * @param string $shortDate Short date * @param string $region Region name * @param string $service Service name * @param string $secretKey Secret Access Key * * @return string */ protected function getSigningKey($shortDate, $region, $service, $secretKey) { $cacheKey = $shortDate . '_' . $region . '_' . $service . '_' . $secretKey; // Retrieve the hash form the cache or create it and add it to the cache if (!isset($this->hashCache[$cacheKey])) { // When the cache size reaches the max, then just clear the cache if (++$this->cacheSize > $this->maxCacheSize) { $this->hashCache = array(); $this->cacheSize = 0; } $dateKey = hash_hmac('sha256', $shortDate, 'AWS4' . $secretKey, true); $regionKey = hash_hmac('sha256', $region, $dateKey, true); $serviceKey = hash_hmac('sha256', $service, $regionKey, true); $this->hashCache[$cacheKey] = hash_hmac('sha256', 'aws4_request', $serviceKey, true); } return $this->hashCache[$cacheKey]; } /** * Get the canonicalized query string for a request * * @param RequestInterface $request * @return string */ private function getCanonicalizedQueryString(RequestInterface $request) { $queryParams = $request->getQuery()->getAll(); unset($queryParams['X-Amz-Signature']); if (empty($queryParams)) { return ''; } $qs = ''; ksort($queryParams); foreach ($queryParams as $key => $values) { if (is_array($values)) { sort($values); } elseif (!$values) { $values = array(''); } foreach ((array) $values as $value) { if ($value === QueryString::BLANK) { $value = ''; } $qs .= rawurlencode($key) . '=' . rawurlencode($value) . '&'; } } return substr($qs, 0, -1); } } client = $client; return $this; } /** * {@inheritdoc} */ public function wait() { if (!$this->client) { throw new RuntimeException('No client has been specified on the waiter'); } parent::wait(); } } config[self::MAX_ATTEMPTS]) ? $this->config[self::MAX_ATTEMPTS] : 10; } /** * Get the amount of time in seconds to delay between attempts * * @return int */ public function getInterval() { return isset($this->config[self::INTERVAL]) ? $this->config[self::INTERVAL] : 0; } /** * {@inheritdoc} */ public function setMaxAttempts($maxAttempts) { $this->config[self::MAX_ATTEMPTS] = $maxAttempts; return $this; } /** * {@inheritdoc} */ public function setInterval($interval) { $this->config[self::INTERVAL] = $interval; return $this; } /** * Set config options associated with the waiter * * @param array $config Options to set * * @return self */ public function setConfig(array $config) { if (isset($config['waiter.before_attempt'])) { $this->getEventDispatcher()->addListener('waiter.before_attempt', $config['waiter.before_attempt']); unset($config['waiter.before_attempt']); } if (isset($config['waiter.before_wait'])) { $this->getEventDispatcher()->addListener('waiter.before_wait', $config['waiter.before_wait']); unset($config['waiter.before_wait']); } $this->config = $config; return $this; } /** * {@inheritdoc} */ public function wait() { $this->attempts = 0; do { $this->dispatch('waiter.before_attempt', array( 'waiter' => $this, 'config' => $this->config, )); if ($this->doWait()) { break; } if (++$this->attempts >= $this->getMaxAttempts()) { throw new RuntimeException('Wait method never resolved to true after ' . $this->attempts . ' attempts'); } $this->dispatch('waiter.before_wait', array( 'waiter' => $this, 'config' => $this->config, )); if ($this->getInterval()) { usleep($this->getInterval() * 1000000); } } while (1); } /** * Method to implement in subclasses * * @return bool Return true when successful, false on failure */ abstract protected function doWait(); } callable = $callable; return $this; } /** * Set additional context for the callable function. This data will be passed into the callable function as the * second argument * * @param array $context Additional context * * @return self */ public function setContext(array $context) { $this->context = $context; return $this; } /** * {@inheritdoc} */ public function doWait() { if (!$this->callable) { throw new RuntimeException('No callable was specified for the wait method'); } return call_user_func($this->callable, $this->attempts, $this->context); } } factories = $factories; } /** * {@inheritdoc} */ public function build($waiter) { if (!($factory = $this->getFactory($waiter))) { throw new InvalidArgumentException("Waiter was not found matching {$waiter}."); } return $factory->build($waiter); } /** * {@inheritdoc} */ public function canBuild($waiter) { return (bool) $this->getFactory($waiter); } /** * Add a factory to the composite factory * * @param WaiterFactoryInterface $factory Factory to add * * @return self */ public function addFactory(WaiterFactoryInterface $factory) { $this->factories[] = $factory; return $this; } /** * Get the factory that matches the waiter name * * @param string $waiter Name of the waiter * * @return WaiterFactoryInterface|bool */ protected function getFactory($waiter) { foreach ($this->factories as $factory) { if ($factory->canBuild($waiter)) { return $factory; } } return false; } } waiterConfig = $waiterConfig; $this->setInterval($waiterConfig->get(WaiterConfig::INTERVAL)); $this->setMaxAttempts($waiterConfig->get(WaiterConfig::MAX_ATTEMPTS)); } /** * {@inheritdoc} */ public function setConfig(array $config) { foreach ($config as $key => $value) { if (substr($key, 0, 7) == 'waiter.') { $this->waiterConfig->set(substr($key, 7), $value); } } if (!isset($config[self::INTERVAL])) { $config[self::INTERVAL] = $this->waiterConfig->get(WaiterConfig::INTERVAL); } if (!isset($config[self::MAX_ATTEMPTS])) { $config[self::MAX_ATTEMPTS] = $this->waiterConfig->get(WaiterConfig::MAX_ATTEMPTS); } return parent::setConfig($config); } /** * Get the waiter's configuration data * * @return WaiterConfig */ public function getWaiterConfig() { return $this->waiterConfig; } /** * {@inheritdoc} */ protected function doWait() { $params = $this->config; // remove waiter settings from the operation's input foreach (array_keys($params) as $key) { if (substr($key, 0, 7) == 'waiter.') { unset($params[$key]); } } $operation = $this->client->getCommand($this->waiterConfig->get(WaiterConfig::OPERATION), $params); try { return $this->checkResult($this->client->execute($operation)); } catch (ValidationException $e) { throw new InvalidArgumentException( $this->waiterConfig->get(WaiterConfig::WAITER_NAME) . ' waiter validation failed: ' . $e->getMessage(), $e->getCode(), $e ); } catch (ServiceResponseException $e) { // Check if this exception satisfies a success or failure acceptor $transition = $this->checkErrorAcceptor($e); if (null !== $transition) { return $transition; } // Check if this exception should be ignored foreach ((array) $this->waiterConfig->get(WaiterConfig::IGNORE_ERRORS) as $ignore) { if ($e->getExceptionCode() == $ignore) { // This exception is ignored, so it counts as a failed attempt rather than a fast-fail return false; } } // Allow non-ignore exceptions to bubble through throw $e; } } /** * Check if an exception satisfies a success or failure acceptor * * @param ServiceResponseException $e * * @return bool|null Returns true for success, false for failure, and null for no transition */ protected function checkErrorAcceptor(ServiceResponseException $e) { if ($this->waiterConfig->get(WaiterConfig::SUCCESS_TYPE) == 'error') { if ($e->getExceptionCode() == $this->waiterConfig->get(WaiterConfig::SUCCESS_VALUE)) { // Mark as a success return true; } } // Mark as an attempt return null; } /** * Check to see if the response model satisfies a success or failure state * * @param Model $result Result model * * @return bool * @throws RuntimeException */ protected function checkResult(Model $result) { // Check if the result evaluates to true based on the path and output model if ($this->waiterConfig->get(WaiterConfig::SUCCESS_TYPE) == 'output' && $this->checkPath( $result, $this->waiterConfig->get(WaiterConfig::SUCCESS_PATH), $this->waiterConfig->get(WaiterConfig::SUCCESS_VALUE) ) ) { return true; } // It did not finish waiting yet. Determine if we need to fail-fast based on the failure acceptor. if ($this->waiterConfig->get(WaiterConfig::FAILURE_TYPE) == 'output') { $failureValue = $this->waiterConfig->get(WaiterConfig::FAILURE_VALUE); if ($failureValue) { $key = $this->waiterConfig->get(WaiterConfig::FAILURE_PATH); if ($this->checkPath($result, $key, $failureValue, false)) { // Determine which of the results triggered the failure $triggered = array_intersect( (array) $this->waiterConfig->get(WaiterConfig::FAILURE_VALUE), array_unique((array) $result->getPath($key)) ); // fast fail because the failure case was satisfied throw new RuntimeException( 'A resource entered into an invalid state of "' . implode(', ', $triggered) . '" while waiting with the "' . $this->waiterConfig->get(WaiterConfig::WAITER_NAME) . '" waiter.' ); } } } return false; } /** * Check to see if the path of the output key is satisfied by the value * * @param Model $model Result model * @param string $key Key to check * @param string $checkValue Compare the key to the value * @param bool $all Set to true to ensure all value match or false to only match one * * @return bool */ protected function checkPath(Model $model, $key = null, $checkValue = array(), $all = true) { // If no key is set, then just assume true because the request succeeded if (!$key) { return true; } if (!($result = $model->getPath($key))) { return false; } $total = $matches = 0; foreach ((array) $result as $value) { $total++; foreach ((array) $checkValue as $check) { if ($value == $check) { $matches++; break; } } } // When matching all values, ensure that the match count matches the total count if ($all && $total != $matches) { return false; } return $matches > 0; } } CamelCase). */ class WaiterClassFactory implements WaiterFactoryInterface { /** * @var array List of namespaces used to look for classes */ protected $namespaces; /** * @var InflectorInterface Inflector used to inflect class names */ protected $inflector; /** * @param array|string $namespaces Namespaces of waiter objects * @param InflectorInterface $inflector Inflector used to resolve class names */ public function __construct($namespaces = array(), InflectorInterface $inflector = null) { $this->namespaces = (array) $namespaces; $this->inflector = $inflector ?: Inflector::getDefault(); } /** * Registers a namespace to check for Waiters * * @param string $namespace Namespace which contains Waiter classes * * @return self */ public function registerNamespace($namespace) { array_unshift($this->namespaces, $namespace); return $this; } /** * {@inheritdoc} */ public function build($waiter) { if (!($className = $this->getClassName($waiter))) { throw new InvalidArgumentException("Waiter was not found matching {$waiter}."); } return new $className(); } /** * {@inheritdoc} */ public function canBuild($waiter) { return $this->getClassName($waiter) !== null; } /** * Get the name of a waiter class * * @param string $waiter Waiter name * * @return string|null */ protected function getClassName($waiter) { $waiterName = $this->inflector->camel($waiter); // Determine the name of the class to load $className = null; foreach ($this->namespaces as $namespace) { $potentialClassName = $namespace . '\\' . $waiterName; if (class_exists($potentialClassName)) { return $potentialClassName; } } return null; } } data = $data; $this->extractConfig(); } /** * Create the command configuration variables */ protected function extractConfig() { // Populate success.* and failure.* if specified in acceptor.* foreach ($this->data as $key => $value) { if (substr($key, 0, 9) == 'acceptor.') { $name = substr($key, 9); if (!isset($this->data["success.{$name}"])) { $this->data["success.{$name}"] = $value; } if (!isset($this->data["failure.{$name}"])) { $this->data["failure.{$name}"] = $value; } unset($this->data[$key]); } } } } config = $config; $this->inflector = $inflector ?: Inflector::getDefault(); } /** * {@inheritdoc} */ public function build($waiter) { return new ConfigResourceWaiter($this->getWaiterConfig($waiter)); } /** * {@inheritdoc} */ public function canBuild($waiter) { return isset($this->config[$waiter]) || isset($this->config[$this->inflector->camel($waiter)]); } /** * Get waiter configuration data, taking __default__ and extensions into account * * @param string $name Waiter name * * @return WaiterConfig * @throws InvalidArgumentException */ protected function getWaiterConfig($name) { if (!$this->canBuild($name)) { throw new InvalidArgumentException('No waiter found matching "' . $name . '"'); } // inflect the name if needed $name = isset($this->config[$name]) ? $name : $this->inflector->camel($name); $waiter = new WaiterConfig($this->config[$name]); $waiter['name'] = $name; // Always use __default__ as the basis if it's set if (isset($this->config['__default__'])) { $parentWaiter = new WaiterConfig($this->config['__default__']); $waiter = $parentWaiter->overwriteWith($waiter); } // Allow for configuration extensions if (isset($this->config[$name]['extends'])) { $waiter = $this->getWaiterConfig($this->config[$name]['extends'])->overwriteWith($waiter); } return $waiter; } } setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/datapipeline-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->setIteratorsConfig(array( 'limit_key' => 'limit', 'more_key' => 'hasMoreResults', 'token_param' => 'marker', 'token_key' => 'marker', 'operations' => array( 'ListPipelines' => array( 'result_key' => 'pipelineIdList', ), 'DescribeObjects' => array( 'result_key' => 'pipelineObjects', ), 'QueryObjects' => array( 'result_key' => 'ids', ), ) )) ->build(); return $client; } } '2012-10-29', 'endpointPrefix' => 'datapipeline', 'serviceFullName' => 'AWS Data Pipeline', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'DataPipeline.', 'signatureVersion' => 'v4', 'namespace' => 'DataPipeline', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'datapipeline.us-east-1.amazonaws.com', ), ), 'operations' => array( 'ActivatePipeline' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ActivatePipeline', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'CreatePipeline' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreatePipelineOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.CreatePipeline', ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'uniqueId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'DeletePipeline' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.DeletePipeline', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'DescribeObjects' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeObjectsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.DescribeObjects', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'objectIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'id', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'evaluateExpressions' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'marker' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'DescribePipelines' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribePipelinesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.DescribePipelines', ), 'pipelineIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'id', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'EvaluateExpression' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EvaluateExpressionOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.EvaluateExpression', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'objectId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'expression' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 20971520, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The specified task was not found.', 'class' => 'TaskNotFoundException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'GetPipelineDefinition' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetPipelineDefinitionOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.GetPipelineDefinition', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'version' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'ListPipelines' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListPipelinesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ListPipelines', ), 'marker' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'PollForTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PollForTaskOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.PollForTask', ), 'workerGroup' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'hostname' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'instanceIdentity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'document' => array( 'type' => 'string', 'maxLength' => 1024, ), 'signature' => array( 'type' => 'string', 'maxLength' => 1024, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified task was not found.', 'class' => 'TaskNotFoundException', ), ), ), 'PutPipelineDefinition' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PutPipelineDefinitionOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.PutPipelineDefinition', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'pipelineObjects' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineObject', 'type' => 'object', 'properties' => array( 'id' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), 'fields' => array( 'required' => true, 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'stringValue' => array( 'type' => 'string', 'maxLength' => 10240, ), 'refValue' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'QueryObjects' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'QueryObjectsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.QueryObjects', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'query' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'selectors' => array( 'type' => 'array', 'items' => array( 'name' => 'Selector', 'type' => 'object', 'properties' => array( 'fieldName' => array( 'type' => 'string', 'maxLength' => 1024, ), 'operator' => array( 'type' => 'object', 'properties' => array( '' => array( ), ), ), ), ), ), ), ), 'sphere' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'marker' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'limit' => array( 'type' => 'numeric', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'ReportTaskProgress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ReportTaskProgressOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ReportTaskProgress', ), 'taskId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified task was not found.', 'class' => 'TaskNotFoundException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'ReportTaskRunnerHeartbeat' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ReportTaskRunnerHeartbeatOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ReportTaskRunnerHeartbeat', ), 'taskrunnerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'workerGroup' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'hostname' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'SetStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.SetStatus', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'objectIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'id', 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), ), 'status' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), ), ), 'SetTaskStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.SetTaskStatus', ), 'taskId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 2048, ), 'taskStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'errorId' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'errorMessage' => array( 'type' => 'string', 'location' => 'json', ), 'errorStackTrace' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The specified task was not found.', 'class' => 'TaskNotFoundException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), 'ValidatePipelineDefinition' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ValidatePipelineDefinitionOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DataPipeline.ValidatePipelineDefinition', ), 'pipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'pipelineObjects' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineObject', 'type' => 'object', 'properties' => array( 'id' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 1024, ), 'fields' => array( 'required' => true, 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'stringValue' => array( 'type' => 'string', 'maxLength' => 10240, ), 'refValue' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'An internal service error occurred.', 'class' => 'InternalServiceErrorException', ), array( 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', 'class' => 'InvalidRequestException', ), array( 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', 'class' => 'PipelineNotFoundException', ), array( 'reason' => 'The specified pipeline has been deleted.', 'class' => 'PipelineDeletedException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreatePipelineOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeObjectsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineObjects' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineObject', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'fields' => array( 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'type' => 'string', ), 'stringValue' => array( 'type' => 'string', ), 'refValue' => array( 'type' => 'string', ), ), ), ), ), ), ), 'marker' => array( 'type' => 'string', 'location' => 'json', ), 'hasMoreResults' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'DescribePipelinesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineDescriptionList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineDescription', 'type' => 'object', 'properties' => array( 'pipelineId' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'fields' => array( 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'type' => 'string', ), 'stringValue' => array( 'type' => 'string', ), 'refValue' => array( 'type' => 'string', ), ), ), ), 'description' => array( 'type' => 'string', ), ), ), ), ), ), 'EvaluateExpressionOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'evaluatedExpression' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'GetPipelineDefinitionOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineObjects' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineObject', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'fields' => array( 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'type' => 'string', ), 'stringValue' => array( 'type' => 'string', ), 'refValue' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ListPipelinesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'pipelineIdList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PipelineIdName', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), ), ), ), 'marker' => array( 'type' => 'string', 'location' => 'json', ), 'hasMoreResults' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'PollForTaskOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'taskObject' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'taskId' => array( 'type' => 'string', ), 'pipelineId' => array( 'type' => 'string', ), 'attemptId' => array( 'type' => 'string', ), 'objects' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'fields' => array( 'type' => 'array', 'items' => array( 'name' => 'Field', 'type' => 'object', 'properties' => array( 'key' => array( 'type' => 'string', ), 'stringValue' => array( 'type' => 'string', ), 'refValue' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'PutPipelineDefinitionOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'validationErrors' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ValidationError', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'errors' => array( 'type' => 'array', 'items' => array( 'name' => 'validationMessage', 'type' => 'string', ), ), ), ), ), 'validationWarnings' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ValidationWarning', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'warnings' => array( 'type' => 'array', 'items' => array( 'name' => 'validationMessage', 'type' => 'string', ), ), ), ), ), 'errored' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'QueryObjectsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ids' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'id', 'type' => 'string', ), ), 'marker' => array( 'type' => 'string', 'location' => 'json', ), 'hasMoreResults' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'ReportTaskProgressOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'canceled' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'ReportTaskRunnerHeartbeatOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'terminate' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'ValidatePipelineDefinitionOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'validationErrors' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ValidationError', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'errors' => array( 'type' => 'array', 'items' => array( 'name' => 'validationMessage', 'type' => 'string', ), ), ), ), ), 'validationWarnings' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ValidationWarning', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'warnings' => array( 'type' => 'array', 'items' => array( 'name' => 'validationMessage', 'type' => 'string', ), ), ), ), ), 'errored' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/directconnect-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->setIteratorsConfig(array( 'operations' => array( 'DescribeConnections' => array( 'result_key' => 'connections', ), 'DescribeOfferings' => array( 'result_key' => 'offerings', ), 'DescribeVirtualGateways' => array( 'result_key' => 'virtualGateways', ), 'DescribeVirtualInterfaces' => array( 'result_key' => 'virtualInterfaces', ), ) )) ->build(); } } '2012-10-25', 'endpointPrefix' => 'directconnect', 'serviceFullName' => 'AWS Direct Connect', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'OvertureService.', 'signatureVersion' => 'v4', 'namespace' => 'DirectConnect', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'directconnect.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'AllocateConnectionOnInterconnect' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connection', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.AllocateConnectionOnInterconnect', ), 'bandwidth' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'connectionName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'ownerAccount' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'interconnectId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'AllocatePrivateVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterface', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.AllocatePrivateVirtualInterface', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'ownerAccount' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'newPrivateVirtualInterfaceAllocation' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'virtualInterfaceName' => array( 'required' => true, 'type' => 'string', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', ), 'asn' => array( 'required' => true, 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'type' => 'string', ), 'customerAddress' => array( 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'AllocatePublicVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterface', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.AllocatePublicVirtualInterface', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'ownerAccount' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'newPublicVirtualInterfaceAllocation' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'virtualInterfaceName' => array( 'required' => true, 'type' => 'string', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', ), 'asn' => array( 'required' => true, 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'required' => true, 'type' => 'string', ), 'customerAddress' => array( 'required' => true, 'type' => 'string', ), 'routeFilterPrefixes' => array( 'required' => true, 'type' => 'array', 'items' => array( 'name' => 'RouteFilterPrefix', 'type' => 'object', 'properties' => array( 'cidr' => array( 'type' => 'string', ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'ConfirmConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ConfirmConnectionResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.ConfirmConnection', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'ConfirmPrivateVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ConfirmPrivateVirtualInterfaceResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.ConfirmPrivateVirtualInterface', ), 'virtualInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'virtualGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'ConfirmPublicVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ConfirmPublicVirtualInterfaceResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.ConfirmPublicVirtualInterface', ), 'virtualInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'CreateConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connection', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.CreateConnection', ), 'location' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'bandwidth' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'connectionName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'CreateInterconnect' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Interconnect', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.CreateInterconnect', ), 'interconnectName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'bandwidth' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'location' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'CreatePrivateVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterface', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.CreatePrivateVirtualInterface', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'newPrivateVirtualInterface' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'virtualInterfaceName' => array( 'required' => true, 'type' => 'string', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', ), 'asn' => array( 'required' => true, 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'type' => 'string', ), 'customerAddress' => array( 'type' => 'string', ), 'virtualGatewayId' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'CreatePublicVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterface', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.CreatePublicVirtualInterface', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'newPublicVirtualInterface' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'virtualInterfaceName' => array( 'required' => true, 'type' => 'string', ), 'vlan' => array( 'required' => true, 'type' => 'numeric', ), 'asn' => array( 'required' => true, 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'required' => true, 'type' => 'string', ), 'customerAddress' => array( 'required' => true, 'type' => 'string', ), 'routeFilterPrefixes' => array( 'required' => true, 'type' => 'array', 'items' => array( 'name' => 'RouteFilterPrefix', 'type' => 'object', 'properties' => array( 'cidr' => array( 'type' => 'string', ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DeleteConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connection', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DeleteConnection', ), 'connectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DeleteInterconnect' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteInterconnectResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DeleteInterconnect', ), 'interconnectId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DeleteVirtualInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteVirtualInterfaceResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DeleteVirtualInterface', ), 'virtualInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeConnections' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connections', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeConnections', ), 'connectionId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeConnectionsOnInterconnect' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Connections', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeConnectionsOnInterconnect', ), 'interconnectId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeInterconnects' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Interconnects', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeInterconnects', ), 'interconnectId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeLocations' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Locations', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeLocations', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeVirtualGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualGateways', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeVirtualGateways', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), 'DescribeVirtualInterfaces' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'VirtualInterfaces', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OvertureService.DescribeVirtualInterfaces', ), 'connectionId' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A server-side error occurred during the API call. The error message will contain additional details about the cause.', 'class' => 'DirectConnectServerException', ), array( 'reason' => 'The API was called with invalid parameters. The error message will contain additional details about the cause.', 'class' => 'DirectConnectClientException', ), ), ), ), 'models' => array( 'Connection' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ownerAccount' => array( 'type' => 'string', 'location' => 'json', ), 'connectionId' => array( 'type' => 'string', 'location' => 'json', ), 'connectionName' => array( 'type' => 'string', 'location' => 'json', ), 'connectionState' => array( 'type' => 'string', 'location' => 'json', ), 'region' => array( 'type' => 'string', 'location' => 'json', ), 'location' => array( 'type' => 'string', 'location' => 'json', ), 'bandwidth' => array( 'type' => 'string', 'location' => 'json', ), 'vlan' => array( 'type' => 'numeric', 'location' => 'json', ), 'partnerName' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'VirtualInterface' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ownerAccount' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceId' => array( 'type' => 'string', 'location' => 'json', ), 'location' => array( 'type' => 'string', 'location' => 'json', ), 'connectionId' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceType' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceName' => array( 'type' => 'string', 'location' => 'json', ), 'vlan' => array( 'type' => 'numeric', 'location' => 'json', ), 'asn' => array( 'type' => 'numeric', 'location' => 'json', ), 'authKey' => array( 'type' => 'string', 'location' => 'json', ), 'amazonAddress' => array( 'type' => 'string', 'location' => 'json', ), 'customerAddress' => array( 'type' => 'string', 'location' => 'json', ), 'virtualInterfaceState' => array( 'type' => 'string', 'location' => 'json', ), 'customerRouterConfig' => array( 'type' => 'string', 'location' => 'json', ), 'virtualGatewayId' => array( 'type' => 'string', 'location' => 'json', ), 'routeFilterPrefixes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'RouteFilterPrefix', 'type' => 'object', 'properties' => array( 'cidr' => array( 'type' => 'string', ), ), ), ), ), ), 'ConfirmConnectionResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'connectionState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ConfirmPrivateVirtualInterfaceResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualInterfaceState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ConfirmPublicVirtualInterfaceResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualInterfaceState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'Interconnect' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'interconnectId' => array( 'type' => 'string', 'location' => 'json', ), 'interconnectName' => array( 'type' => 'string', 'location' => 'json', ), 'interconnectState' => array( 'type' => 'string', 'location' => 'json', ), 'region' => array( 'type' => 'string', 'location' => 'json', ), 'location' => array( 'type' => 'string', 'location' => 'json', ), 'bandwidth' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteInterconnectResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'interconnectState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteVirtualInterfaceResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualInterfaceState' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'Connections' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'connections' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Connection', 'type' => 'object', 'properties' => array( 'ownerAccount' => array( 'type' => 'string', ), 'connectionId' => array( 'type' => 'string', ), 'connectionName' => array( 'type' => 'string', ), 'connectionState' => array( 'type' => 'string', ), 'region' => array( 'type' => 'string', ), 'location' => array( 'type' => 'string', ), 'bandwidth' => array( 'type' => 'string', ), 'vlan' => array( 'type' => 'numeric', ), 'partnerName' => array( 'type' => 'string', ), ), ), ), ), ), 'Interconnects' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'interconnects' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Interconnect', 'type' => 'object', 'properties' => array( 'interconnectId' => array( 'type' => 'string', ), 'interconnectName' => array( 'type' => 'string', ), 'interconnectState' => array( 'type' => 'string', ), 'region' => array( 'type' => 'string', ), 'location' => array( 'type' => 'string', ), 'bandwidth' => array( 'type' => 'string', ), ), ), ), ), ), 'Locations' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'locations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Location', 'type' => 'object', 'properties' => array( 'locationCode' => array( 'type' => 'string', ), 'locationName' => array( 'type' => 'string', ), ), ), ), ), ), 'VirtualGateways' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualGateways' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VirtualGateway', 'type' => 'object', 'properties' => array( 'virtualGatewayId' => array( 'type' => 'string', ), 'virtualGatewayState' => array( 'type' => 'string', ), ), ), ), ), ), 'VirtualInterfaces' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'virtualInterfaces' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VirtualInterface', 'type' => 'object', 'properties' => array( 'ownerAccount' => array( 'type' => 'string', ), 'virtualInterfaceId' => array( 'type' => 'string', ), 'location' => array( 'type' => 'string', ), 'connectionId' => array( 'type' => 'string', ), 'virtualInterfaceType' => array( 'type' => 'string', ), 'virtualInterfaceName' => array( 'type' => 'string', ), 'vlan' => array( 'type' => 'numeric', ), 'asn' => array( 'type' => 'numeric', ), 'authKey' => array( 'type' => 'string', ), 'amazonAddress' => array( 'type' => 'string', ), 'customerAddress' => array( 'type' => 'string', ), 'virtualInterfaceState' => array( 'type' => 'string', ), 'customerRouterConfig' => array( 'type' => 'string', ), 'virtualGatewayId' => array( 'type' => 'string', ), 'routeFilterPrefixes' => array( 'type' => 'array', 'items' => array( 'name' => 'RouteFilterPrefix', 'type' => 'object', 'properties' => array( 'cidr' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ); setNext($next); } } /** * {@inheridoc} */ public function makesDecision() { return true; } /** * {@inheritdoc} */ protected function getDelay( $retries, RequestInterface $request, Response $response = null, HttpException $e = null ) { if ($response) { // Validate the checksum against our computed checksum if ($checksum = (string) $response->getHeader('x-amz-crc32')) { // Retry the request if the checksums don't match, otherwise, return null return $checksum != hexdec(Stream::getHash($response->getBody(), 'crc32b')) ? true : null; } } } } setConfig($config) ->setConfigDefaults(array( // DynamoDB does not use redirects self::DISABLE_REDIRECTS => true, Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/dynamodb-%s.php', // DynamoDB does not require response processing other than turning JSON into an array self::COMMAND_PARAMS => array(Cmd::RESPONSE_PROCESSING => Cmd::TYPE_NO_TRANSLATION) )) ->setExceptionParser($exceptionParser) ->setIteratorsConfig(array( 'result_key' => 'Items', 'token_param' => 'ExclusiveStartKey', 'token_key' => 'LastEvaluatedKey', 'operations' => array( 'BatchGetItem' => array( 'token_param' => 'RequestItems', 'token_key' => 'UnprocessedKeys', 'result_key' => 'Responses/*', ), 'ListTables' => array( 'result_key' => 'TableNames', 'token_param' => 'ExclusiveStartTableName', 'token_key' => 'LastEvaluatedTableName', ), 'Query', 'Scan', ) )) ->build(); } /** * Formats a value as a DynamoDB attribute. * * @param mixed $value The value to format for DynamoDB. * @param string $format The type of format (e.g. put, update). * * @return array The formatted value. */ public function formatValue($value, $format = Attribute::FORMAT_PUT) { return Attribute::factory($value)->getFormatted($format); } /** * Formats an array of values as DynamoDB attributes. * * @param array $values The values to format for DynamoDB. * @param string $format The type of format (e.g. put, update). * * @return array The formatted values. */ public function formatAttributes(array $values, $format = Attribute::FORMAT_PUT) { $formatted = array(); foreach ($values as $key => $value) { $formatted[$key] = $this->formatValue($value, $format); } return $formatted; } /** * Calculate the amount of time needed for an exponential backoff to wait * before retrying a request * * @param int $retries Number of retries * * @return float Returns the amount of time to wait in seconds */ public static function calculateRetryDelay($retries) { return $retries == 0 ? 0 : (50 * (int) pow(2, $retries - 1)) / 1000; } /** * Convenience method for instantiating and registering the DynamoDB * Session handler with this DynamoDB client object. * * @param array $config Array of options for the session handler factory * * @return SessionHandler */ public function registerSessionHandler(array $config = array()) { $config = array_replace(array('dynamodb_client' => $this), $config); $handler = SessionHandler::factory($config); $handler->register(); return $handler; } } addItem($unprocessedItem); } } /** * Adds an unprocessed write request to the collection * * @param WriteRequestInterface $unprocessedItem * * @return UnprocessedWriteRequestsException */ public function addItem(WriteRequestInterface $unprocessedItem) { $this->items[] = $unprocessedItem; return $this; } /** * Get the total number of request exceptions * * @return int */ public function count() { return count($this->items); } /** * Allows array-like iteration over the request exceptions * * @return \ArrayIterator */ public function getIterator() { return new \ArrayIterator($this->items); } } get('Items'))) { if ($item = $result->get('Item') ?: $result->get('Attributes')) { $items = array($item); } else { $items = $result->getPath('Responses/*'); } } return new self(new \ArrayIterator($items ?: array())); } /** * Ensures that the inner iterator is both Traversable and Countable * * {@inheritdoc} * * @throws InvalidArgumentException */ public function __construct(\Traversable $iterator) { if (!($iterator instanceof \Countable)) { throw new InvalidArgumentException('The inner iterator for an ItemIterator must be Countable.'); } parent::__construct($iterator); } /** * Returns the first item in the iterator */ public function getFirst() { $this->rewind(); return $this->current(); } /** * {@inheritdoc} * @return Collection */ public function current() { return new Collection(array_map(array($this, 'processAttribute'), parent::current())); } public function count() { return $this->getInnerIterator()->count(); } public function toArray() { return iterator_to_array($this, false); } /** * Converts an item's attribute from the DynamoDB format to a typeless value in order to simplify the overall * array structure of an item. The method also base64 decodes the value any Binary attributes * * @param array $attribute * * @return array|string */ protected function processAttribute(array $attribute) { list($type, $value) = each($attribute); if ($type === 'B') { $value = base64_decode($value); } elseif ($type === 'BS') { $value = array_map('base64_decode', $value); } return $value; } } scannedCount; } /** * {@inheritdoc} */ protected function handleResults(Model $result) { $this->scannedCount += (int) $result->get('ScannedCount'); return parent::handleResults($result); } } 1) { throw new InvalidArgumentException('Sets must be at most one level deep.'); } // Handle specific, allowed object types if ($value instanceof Attribute) { return $value; } elseif ($value instanceof \Traversable) { $value = iterator_to_array($value); } elseif (is_object($value) && method_exists($value, '__toString')) { $value = (string) $value; } // Ensure that the value is valid if ($value === null || $value === array() || $value === '') { // Note: "Empty" values are not allowed except for zero and false. throw new InvalidArgumentException('The value must not be empty.'); } elseif (is_resource($value) || is_object($value)) { throw new InvalidArgumentException('The value must be able to be converted to string.'); } // Create the attribute to return if (is_int($value) || is_float($value)) { // Handle numeric values $attribute = new Attribute((string) $value, Type::NUMBER); } elseif (is_bool($value)) { // Handle boolean values $attribute = new Attribute($value ? '1' : '0', Type::NUMBER); } elseif (is_array($value) || $value instanceof \Traversable) { // Handle arrays $setType = null; $attribute = new Attribute(array()); // Loop through each value to analyze and prepare it foreach ($value as $subValue) { // Recursively get the attribute for the set. The depth param only allows one level of recursion $subAttribute = static::factory($subValue, $depth + 1); // The type of each sub-value must be the same, or else the whole array is invalid if ($setType === null) { $setType = $subAttribute->type; } elseif ($setType !== $subAttribute->type) { throw new InvalidArgumentException('The set did not contain values of a uniform type.'); } // Save the value for the upstream array $attribute->value[] = (string) $subAttribute->value; } // Make sure the type is changed to be a set type $attribute->type = $setType . self::SET_SUFFIX; } else { $attribute = new Attribute((string) $value); } return $attribute; } /** * Instantiates a DynamoDB attribute. * * @param string|array $value The DynamoDB attribute value * @param string $type The DynamoDB attribute type (N, S, B, NS, SS, BS) */ public function __construct($value, $type = Type::STRING) { $this->setValue($value); $this->setType($type); } /** * Convert the attribute to a string * * @return string */ public function __toString() { return implode(', ', (array) $this->value); } /** * Retrieve the formatted data * * @param string $format The format to apply to the data * * @return string The formatted version of the data */ public function getFormatted($format = Attribute::FORMAT_PUT) { switch ($format) { case self::FORMAT_EXPECTED: // no break case self::FORMAT_UPDATE: $formatted = array('Value' => array($this->type => $this->value)); break; case self::FORMAT_PUT: // no break default: $formatted = array($this->type => $this->value); } return $formatted; } /** * Retrieve the attribute type * * @return string The attribute type */ public function getType() { return $this->type; } /** * Retrieve the attribute value * * @return string The attribute value */ public function getValue() { return $this->value; } /** * Set the attribute type * * @param string $type The attribute type to set * * @return self * @throws InvalidArgumentException */ public function setType($type) { if (in_array($type, Type::values())) { $this->type = $type; } else { throw new InvalidArgumentException('An attribute type must be a valid DynamoDB type.'); } return $this; } /** * Set the attribute value * * @param string|array $value The attribute value * * @return self * @throws InvalidArgumentException */ public function setValue($value) { if (is_string($value) || is_array($value)) { $this->value = $value; } else { throw new InvalidArgumentException('An attribute value may only be a string or array.'); } return $this; } /** * {@inheritdoc} */ public function toArray() { return $this->getFormatted(); } } tableName; } } getName() !== 'DeleteItem') { throw new InvalidArgumentException(); } // Get relevant data for a DeleteRequest $table = $command->get('TableName'); $key = $command->get('Key'); // Return an instantiated DeleteRequest object return new DeleteRequest($key, $table); } /** * Constructs a new delete request * * @param array $key The key of the item to delete * @param string $tableName The name of the table which has the item */ public function __construct(array $key, $tableName) { $this->key = $key; $this->tableName = $tableName; } /** * The parameter form of the request * * @return array */ public function toArray() { $key = $this->key; foreach ($key as &$element) { if ($element instanceof Attribute) { $element = $element->toArray(); } } return array('DeleteRequest' => array('Key' => $key)); } /** * Get the key * * @return array */ public function getKey() { return $this->key; } } getName() !== 'PutItem') { throw new InvalidArgumentException(); } // Get relevant data for a PutRequest $table = $command->get('TableName'); $item = $command->get('Item'); // Create an Item object from the 'item' command data if (!($item instanceof Item)) { $item = new Item($item, $table); } // Return an instantiated PutRequest object return new PutRequest($item, $table); } /** * Constructs a new put request * * @param Item $item The item to put into DynamoDB * @param string $tableName The name of the table which has the item * * @throw InvalidArgumentException if the table name is not provided */ public function __construct(Item $item, $tableName = null) { $this->item = $item; $this->tableName = $tableName ?: $item->getTableName(); if (!$this->tableName) { throw new InvalidArgumentException('A table name is required to create a PutRequest.'); } } /** * The parameter form of the request * * @return array */ public function toArray() { return array('PutRequest' => array('Item' => $this->item->toArray())); } /** * Get the item * * @return Item */ public function getItem() { return $this->item; } } data = $data; $this->tableName = $tableName; } /** * The parameter form of the request * * @return array */ public function toArray() { return $this->data; } } createBatchesWith(new BatchSizeDivisor($batchSize)) ->transferWith(new WriteRequestBatchTransfer($client)); if ($notify) { $builder->notify($notify); } $batch = new self($builder->build()); $batch = new FlushingBatch($batch, $batchSize); return $batch; } /** * {@inheritdoc} */ public function add($item) { if ($item instanceof AbstractCommand) { // Convert PutItem and DeleteItem into the correct format $name = $item->getName(); if (in_array($name, array('PutItem', 'DeleteItem'))) { $class = __NAMESPACE__ . '\\' . str_replace('Item', 'Request', $name); $item = $class::fromCommand($item); } else { throw new InvalidArgumentException('The command provided was not a PutItem or DeleteItem command.'); } } if (!($item instanceof WriteRequestInterface)) { throw new InvalidArgumentException('The item are are trying to add to the batch queue is invalid.'); } return $this->decoratedBatch->add($item); } /** * {@inheritdoc} */ public function flush() { // Flush the queue $items = array(); while (!$this->decoratedBatch->isEmpty()) { try { $items = array_merge($items, $this->decoratedBatch->flush()); } catch (BatchTransferException $e) { $unprocessed = $e->getPrevious(); if ($unprocessed instanceof UnprocessedWriteRequestsException) { // Handles the UnprocessedItemsException that may occur for // throttled items the batch. These are re-queued here foreach ($unprocessed as $unprocessedItem) { $this->add($unprocessedItem); } } else { // Re-throw the exception if not handled throw $e; } } } return $items; } } client = $client; } /** * {@inheritdoc} */ public function transfer(array $batch) { // Create a container exception for any unprocessed items $unprocessed = new UnprocessedWriteRequestsException(); // Execute the transfer logic $this->performTransfer($batch, $unprocessed); // Throw an exception containing the unprocessed items if there are any if (count($unprocessed)) { throw $unprocessed; } } /** * Transfer a batch of requests and collect any unprocessed items * * @param array $batch A batch of write requests * @param UnprocessedWriteRequestsException $unprocessedRequests Collection of unprocessed items * * @throws \Guzzle\Common\Exception\ExceptionCollection */ protected function performTransfer( array $batch, UnprocessedWriteRequestsException $unprocessedRequests ) { // Do nothing if the batch is empty if (empty($batch)) { return; } // Chunk the array and prepare a set of parallel commands $commands = array(); foreach (array_chunk($batch, self::BATCH_WRITE_MAX_SIZE) as $chunk) { // Convert the request items into the format required by the client $items = array(); foreach ($chunk as $item) { if ($item instanceof AbstractWriteRequest) { /** @var $item AbstractWriteRequest */ $table = $item->getTableName(); if (!isset($items[$table])) { $items[$table] = array(); } $items[$table][] = $item->toArray(); } } // Create the BatchWriteItem request $commands[] = $this->client->getCommand('BatchWriteItem', array( 'RequestItems' => $items, Ua::OPTION => Ua::BATCH )); } // Execute the commands and handle exceptions try { $commands = $this->client->execute($commands); $this->getUnprocessedRequestsFromCommands($commands, $unprocessedRequests); } catch (ExceptionCollection $exceptions) { // Create a container exception for any unhandled (true) exceptions $unhandledExceptions = new ExceptionCollection(); // Loop through caught exceptions and handle RequestTooLarge scenarios /** @var $e DynamoDbException */ foreach ($exceptions as $e) { if ($e instanceof DynamoDbException && $e->getStatusCode() === 413) { $request = $e->getResponse()->getRequest(); $this->retryLargeRequest($request, $unprocessedRequests); } else { $unhandledExceptions->add($e); } } // If there were unhandled exceptions, throw them if (count($unhandledExceptions)) { throw $unhandledExceptions; } } } /** * Handles unprocessed items from the executed commands. Unprocessed items * can be collected and thrown in an UnprocessedWriteRequestsException * * @param array $commands Array of commands * @param UnprocessedWriteRequestsException $unprocessedRequests Collection of unprocessed items */ protected function getUnprocessedRequestsFromCommands( array $commands, UnprocessedWriteRequestsException $unprocessedRequests ) { /** @var $command CommandInterface */ foreach ($commands as $command) { if ($command instanceof CommandInterface && $command->isExecuted()) { $result = $command->getResult(); $items = $this->convertResultsToUnprocessedRequests($result['UnprocessedItems']); foreach ($items as $request) { $unprocessedRequests->addItem($request); } } } } /** * Handles exceptions caused by the request being too large (over 1 MB). The * response will have a status code of 413. In this case the batch should be * split up into smaller batches and retried. * * @param EntityEnclosingRequestInterface $request The failed request * @param UnprocessedWriteRequestsException $unprocessedRequests Collection of unprocessed items */ protected function retryLargeRequest( EntityEnclosingRequestInterface $request, UnprocessedWriteRequestsException $unprocessedRequests ) { // Collect the items out from the request object $items = json_decode($request->getBody(true), true); $items = $this->convertResultsToUnprocessedRequests($items['RequestItems']); // Divide batch into smaller batches and transfer them via recursion // NOTE: Dividing the batch into 3 (instead of 2) batches resulted in less recursion during testing if ($items) { $newBatches = array_chunk($items, ceil(count($items) / 3)); foreach ($newBatches as $newBatch) { $this->performTransfer($newBatch, $unprocessedRequests); } } } /** * Collects and creates unprocessed request objects from data collected from erroneous cases * * @param array $items Data formatted under "RequestItems" or "UnprocessedItems" keys * * @return array */ protected function convertResultsToUnprocessedRequests(array $items) { $unprocessed = array(); foreach ($items as $table => $requests) { foreach ($requests as $request) { $unprocessed[] = new UnprocessedRequest($request, $table); } } return $unprocessed; } } data; foreach ($result as &$value) { if ($value instanceof Attribute) { $value = $value->toArray(); } } return $result; } /** * Construct a new Item * * @param array $attributes Array of attributes * @param string $tableName Table of the item (if known) */ public function __construct(array $attributes = array(), $tableName = null) { $this->replace($attributes); $this->tableName = $tableName; } /** * Set the name of the table associated with the item * * @param string $tableName Table name * * @return self */ public function setTableName($tableName) { $this->tableName = $tableName; return $this; } /** * Get the name of the table associated with the item * * @return string|null */ public function getTableName() { return $this->tableName; } /** * Get an attribute object by name * * @param string $name Name of the attribute to retrieve * * @return Attribute|null */ public function get($name) { return isset($this->data[$name]) ? $this->data[$name] : null; } /** * Get all of the attribute names of the item * * @return array */ public function keys() { return array_keys($this->data); } /** * Check if a particular attribute exists on the item * * @param string $attribute Attribute name to check * * @return bool */ public function has($attribute) { return isset($this->data[$attribute]); } /** * Get all of the {@see Attribute} objects * * @return array */ public function all() { return $this->data; } /** * Add an attribute * * @param string $name Name of the attribute to add * @param Attribute $attribute Attribute to add * * @return self */ public function add($name, Attribute $attribute) { $this->data[$name] = $attribute; return $this; } /** * Set all of the attributes * * @param array $attributes Array of {@see Attribute} objects * * @return self */ public function replace(array $attributes) { foreach ($attributes as $name => $attribute) { if (!($attribute instanceof Attribute)) { $attribute = new Attribute(current($attribute), key($attribute)); } $this->add($name, $attribute); } return $this; } /** * Remove an attribute by name * * @param string $name Name of the attribute to remove * * @return self */ public function remove($name) { unset($this->data[$name]); return $this; } /** * Get the total number of attributes * * @return int */ public function count() { return count($this->data); } /** * {@inheritdoc} */ public function getIterator() { return new \ArrayIterator($this->data); } /** * ArrayAccess implementation of offsetExists() * * @param string $offset Array key * * @return bool */ public function offsetExists($offset) { return isset($this->data[$offset]); } /** * ArrayAccess implementation of offsetGet() * * @param string $offset Array key * * @return null|mixed */ public function offsetGet($offset) { return isset($this->data[$offset]) ? $this->data[$offset] : null; } /** * ArrayAccess implementation of offsetGet() * * @param string $offset Array key * @param mixed $value Value to set */ public function offsetSet($offset, $value) { $this->data[$offset] = $value; } /** * ArrayAccess implementation of offsetUnset() * * @param string $offset Array key */ public function offsetUnset($offset) { unset($this->data[$offset]); } } '2011-12-05', 'endpointPrefix' => 'dynamodb', 'serviceFullName' => 'Amazon DynamoDB', 'serviceAbbreviation' => 'DynamoDB', 'serviceType' => 'json', 'jsonVersion' => '1.0', 'targetPrefix' => 'DynamoDB_20111205.', 'signatureVersion' => 'v4', 'namespace' => 'DynamoDb', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.sa-east-1.amazonaws.com', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'dynamodb.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'BatchGetItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'BatchGetItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves the attributes for multiple items from multiple tables using their primary keys.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.BatchGetItem', ), 'RequestItems' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'TableName', 'key_pattern' => '/[a-zA-Z0-9_.-]+/', ), 'properties' => array( 'Keys' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'maxItems' => 100, 'items' => array( 'name' => 'Key', 'description' => 'The primary key that uniquely identifies each item in a table. A primary key can be a one attribute (hash) primary key or a two attribute (hash-and-range) primary key.', 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'BatchWriteItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'BatchWriteItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Allows to execute a batch of Put and/or Delete Requests for many tables in a single call. A total of 25 requests are allowed.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.BatchWriteItem', ), 'RequestItems' => array( 'required' => true, 'description' => 'A map of table name to list-of-write-requests. Used as input to the BatchWriteItem API call', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'minItems' => 1, 'maxItems' => 25, 'data' => array( 'shape_name' => 'TableName', 'key_pattern' => '/[a-zA-Z0-9_.-]+/', ), 'items' => array( 'name' => 'WriteRequest', 'description' => 'This structure is a Union of PutRequest and DeleteRequest. It can contain exactly one of PutRequest or DeleteRequest. Never Both. This is enforced in the code.', 'type' => 'object', 'properties' => array( 'PutRequest' => array( 'type' => 'object', 'properties' => array( 'Item' => array( 'required' => true, 'description' => 'The item to put', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'DeleteRequest' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'required' => true, 'description' => 'The item\'s key to be delete', 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateTableOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Adds a new table to your account.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.CreateTable', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table you want to create. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'KeySchema' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'AttributeType' => array( 'required' => true, 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', 'enum' => array( 'S', 'N', 'B', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'AttributeType' => array( 'required' => true, 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', 'enum' => array( 'S', 'N', 'B', ), ), ), ), ), ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'description' => 'ReadCapacityUnits are in terms of strictly consistent reads, assuming items of 1k. 2k items require twice the ReadCapacityUnits. Eventually-consistent reads only require half the ReadCapacityUnits of stirctly consistent reads.', 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'description' => 'WriteCapacityUnits are in terms of strictly consistent reads, assuming items of 1k. 2k items require twice the WriteCapacityUnits.', 'type' => 'numeric', 'minimum' => 1, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'This exception is thrown when the subscriber exceeded the limits on the number of objects or operations.', 'class' => 'LimitExceededException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Deletes a single item in a table by primary key.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.DeleteItem', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to delete an item. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'Allows you to provide an attribute name, and whether or not Amazon DynamoDB should check to see if the attribute value already exists; or if the attribute value exists and has a particular value before changing it.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'description' => 'Specify whether or not a value already exists and has a specific content for the attribute name-value pair.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'description' => 'Specify whether or not a value already exists for the attribute name-value pair.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'NONE', 'ALL_OLD', 'UPDATED_OLD', 'ALL_NEW', 'UPDATED_NEW', ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when an expected value does not match what was found in the system.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteTableOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Deletes a table and all of its items.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.DeleteTable', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table you want to delete. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the subscriber exceeded the limits on the number of objects or operations.', 'class' => 'LimitExceededException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTableOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves information about the table, including the current status of the table, the primary key schema and when the table was created.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.DescribeTable', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table you want to describe. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'GetItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves a set of Attributes for an item that matches the primary key.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.GetItem', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to get an item. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'ListTables' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListTablesOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves a paginated list of table names created by the AWS Account of the caller in the AWS Region (e.g. us-east-1).', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.ListTables', ), 'ExclusiveStartTableName' => array( 'description' => 'The name of the table that starts the list. If you already ran a ListTables operation and received a LastEvaluatedTableName value in the response, use that value here to continue the list.', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'PutItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PutItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Creates a new item, or replaces an old item with a new item (including all the attributes).', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.PutItem', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to put an item. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Item' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'Allows you to provide an attribute name, and whether or not Amazon DynamoDB should check to see if the attribute value already exists; or if the attribute value exists and has a particular value before changing it.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'description' => 'Specify whether or not a value already exists and has a specific content for the attribute name-value pair.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'description' => 'Specify whether or not a value already exists for the attribute name-value pair.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'NONE', 'ALL_OLD', 'UPDATED_OLD', 'ALL_NEW', 'UPDATED_NEW', ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when an expected value does not match what was found in the system.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'Query' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'QueryOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Gets the values of one or more items and its attributes by primary key (composite primary key, only).', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.Query', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to query. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'Limit' => array( 'description' => 'The maximum number of items to return. If Amazon DynamoDB hits this limit while querying the table, it stops the query and returns the matching values up to the limit, and a LastEvaluatedKey to apply in a subsequent operation to continue the query. Also, if the result set size exceeds 1MB before Amazon DynamoDB hits this limit, it stops the query and returns the matching values, and a LastEvaluatedKey to apply in a subsequent operation to continue the query.', 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'Count' => array( 'description' => 'If set to true, Amazon DynamoDB returns a total number of items that match the query parameters, instead of a list of the matching items and their attributes. Do not set Count to true while providing a list of AttributesToGet, otherwise Amazon DynamoDB returns a validation error.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'HashKeyValue' => array( 'required' => true, 'description' => 'Attribute value of the hash component of the composite primary key.', 'type' => 'object', 'location' => 'json', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyCondition' => array( 'description' => 'A container for the attribute values and comparison operators to use for the query.', 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeValueList' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeValue', 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'EQ', 'NE', 'IN', 'LE', 'LT', 'GE', 'GT', 'BETWEEN', 'NOT_NULL', 'NULL', 'CONTAINS', 'NOT_CONTAINS', 'BEGINS_WITH', ), ), ), ), 'ScanIndexForward' => array( 'description' => 'Specifies forward or backward traversal of the index. Amazon DynamoDB returns results reflecting the requested order, determined by the range key. The default value is true (forward).', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'ExclusiveStartKey' => array( 'description' => 'Primary key of the item from which to continue an earlier query. An earlier query might provide this value as the LastEvaluatedKey if that query operation was interrupted before completing the query; either because of the result set size or the Limit parameter. The LastEvaluatedKey can be passed back in a new query request to continue the operation from that point.', 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'Scan' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ScanOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Retrieves one or more items and its attributes by performing a full scan of a table.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.Scan', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to scan. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'Limit' => array( 'description' => 'The maximum number of items to return. If Amazon DynamoDB hits this limit while scanning the table, it stops the scan and returns the matching values up to the limit, and a LastEvaluatedKey to apply in a subsequent operation to continue the scan. Also, if the scanned data set size exceeds 1 MB before Amazon DynamoDB hits this limit, it stops the scan and returns the matching values up to the limit, and a LastEvaluatedKey to apply in a subsequent operation to continue the scan.', 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), 'Count' => array( 'description' => 'If set to true, Amazon DynamoDB returns a total number of items for the Scan operation, even if the operation has no matching items for the assigned filter. Do not set Count to true while providing a list of AttributesToGet, otherwise Amazon DynamoDB returns a validation error.', 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'ScanFilter' => array( 'description' => 'Evaluates the scan results and returns only the desired values.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'String', ), 'properties' => array( 'AttributeValueList' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeValue', 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'EQ', 'NE', 'IN', 'LE', 'LT', 'GE', 'GT', 'BETWEEN', 'NOT_NULL', 'NULL', 'CONTAINS', 'NOT_CONTAINS', 'BEGINS_WITH', ), ), ), ), ), 'ExclusiveStartKey' => array( 'description' => 'Primary key of the item from which to continue an earlier scan. An earlier scan might provide this value if that scan operation was interrupted before scanning the entire table; either because of the result set size or the Limit parameter. The LastEvaluatedKey can be passed back in a new scan request to continue the operation from that point.', 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateItemOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Edits an existing item\'s attributes.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.UpdateItem', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table in which you want to update an item. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'required' => true, 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), 'AttributeUpdates' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'Specifies the attribute to update and how to perform the update. Possible values: PUT (default), ADD or DELETE.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Action' => array( 'type' => 'string', 'enum' => array( 'ADD', 'PUT', 'DELETE', ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'Allows you to provide an attribute name, and whether or not Amazon DynamoDB should check to see if the attribute value already exists; or if the attribute value exists and has a particular value before changing it.', 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'description' => 'Specify whether or not a value already exists and has a specific content for the attribute name-value pair.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'description' => 'Specify whether or not a value already exists for the attribute name-value pair.', 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'NONE', 'ALL_OLD', 'UPDATED_OLD', 'ALL_NEW', 'UPDATED_NEW', ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when an expected value does not match what was found in the system.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'This exception is thrown when the level of provisioned throughput defined for the table is exceeded.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateTableOutput', 'responseType' => 'model', 'responseNotes' => 'Returns a json_decoded array of the response body', 'summary' => 'Updates the provisioned throughput for the given table.', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20111205.UpdateTable', ), 'TableName' => array( 'required' => true, 'description' => 'The name of the table you want to update. Allowed characters are a-z, A-Z, 0-9, _ (underscore), - (hyphen) and . (period).', 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'description' => 'ReadCapacityUnits are in terms of strictly consistent reads, assuming items of 1k. 2k items require twice the ReadCapacityUnits. Eventually-consistent reads only require half the ReadCapacityUnits of stirctly consistent reads.', 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'description' => 'WriteCapacityUnits are in terms of strictly consistent reads, assuming items of 1k. 2k items require twice the WriteCapacityUnits.', 'type' => 'numeric', 'minimum' => 1, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'This exception is thrown when the resource which is being attempted to be changed is in use.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'This exception is thrown when the subscriber exceeded the limits on the number of objects or operations.', 'class' => 'LimitExceededException', ), array( 'reason' => 'This exception is thrown when the service has a problem when trying to process the request.', 'class' => 'InternalServerErrorException', ), ), ), ), 'models' => array( 'BatchGetItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Responses' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'The item attributes from a response in a specific table, along with the read resources consumed on the table during the request.', 'type' => 'object', 'properties' => array( 'Items' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'UnprocessedKeys' => array( 'description' => 'Contains a map of tables and their respective keys that were not processed with the current response, possibly due to reaching a limit on the response size. The UnprocessedKeys value is in the same form as a RequestItems parameter (so the value can be provided directly to a subsequent BatchGetItem operation). For more information, see the above RequestItems parameter.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'Keys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'description' => 'The primary key that uniquely identifies each item in a table. A primary key can be a one attribute (hash) primary key or a two attribute (hash-and-range) primary key.', 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', ), ), ), ), ), ), 'BatchWriteItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Responses' => array( 'description' => 'The response object as a result of BatchWriteItem call. This is essentially a map of table name to ConsumedCapacityUnits.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'ConsumedCapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'UnprocessedItems' => array( 'description' => 'The Items which we could not successfully process in a BatchWriteItem call is returned as UnprocessedItems', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'WriteRequest', 'description' => 'This structure is a Union of PutRequest and DeleteRequest. It can contain exactly one of PutRequest or DeleteRequest. Never Both. This is enforced in the code.', 'type' => 'object', 'properties' => array( 'PutRequest' => array( 'type' => 'object', 'properties' => array( 'Item' => array( 'description' => 'The item to put', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), ), 'DeleteRequest' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'description' => 'The item\'s key to be delete', 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), ), ), ), 'CreateTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'description' => 'The name of the table being described.', 'type' => 'string', ), 'KeySchema' => array( 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), 'DeleteItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'description' => 'If the ReturnValues parameter is provided as ALL_OLD in the request, Amazon DynamoDB returns an array of attribute name-value pairs (essentially, the deleted item). Otherwise, the response contains an empty set.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DeleteTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'description' => 'The name of the table being described.', 'type' => 'string', ), 'KeySchema' => array( 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), 'DescribeTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Table' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'description' => 'The name of the table being described.', 'type' => 'string', ), 'KeySchema' => array( 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), 'GetItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Item' => array( 'description' => 'Contains the requested attributes.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'ListTablesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableNames' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TableName', 'type' => 'string', ), ), 'LastEvaluatedTableName' => array( 'description' => 'The name of the last table in the current list. Use this value as the ExclusiveStartTableName in a new request to continue the list until all the table names are returned. If this value is null, all table names have been returned.', 'type' => 'string', 'location' => 'json', ), ), ), 'PutItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'description' => 'Attribute values before the put operation, but only if the ReturnValues parameter is specified as ALL_OLD in the request.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'QueryOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'Count' => array( 'description' => 'Number of items in the response.', 'type' => 'numeric', 'location' => 'json', ), 'LastEvaluatedKey' => array( 'description' => 'Primary key of the item where the query operation stopped, inclusive of the previous result set. Use this value to start a new operation excluding this value in the new request. The LastEvaluatedKey is null when the entire query result set is complete (i.e. the operation processed the "last page").', 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'ScanOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'Count' => array( 'description' => 'Number of items in the response.', 'type' => 'numeric', 'location' => 'json', ), 'ScannedCount' => array( 'description' => 'Number of items in the complete scan before any filters are applied. A high ScannedCount value with few, or no, Count results indicates an inefficient Scan operation.', 'type' => 'numeric', 'location' => 'json', ), 'LastEvaluatedKey' => array( 'description' => 'Primary key of the item where the scan operation stopped. Provide this value in a subsequent scan operation to continue the operation from that point. The LastEvaluatedKey is null when the entire scan result set is complete (i.e. the operation processed the "last page").', 'type' => 'object', 'location' => 'json', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'UpdateItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'description' => 'A map of attribute name-value pairs, but only if the ReturnValues parameter is specified as something other than NONE in the request.', 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'description' => 'AttributeValue can be String, Number, Binary, StringSet, NumberSet, BinarySet.', 'type' => 'object', 'properties' => array( 'S' => array( 'description' => 'Strings are Unicode with UTF-8 binary encoding. The maximum size is limited by the size of the primary key (1024 bytes as a range part of a key or 2048 bytes as a single part hash key) or the item size (64k).', 'type' => 'string', ), 'N' => array( 'description' => 'Numbers are positive or negative exact-value decimals and integers. A number can have up to 38 digits precision and can be between 10^-128 to 10^+126.', 'type' => 'string', ), 'B' => array( 'description' => 'Binary attributes are sequences of unsigned bytes.', 'type' => 'string', ), 'SS' => array( 'description' => 'A set of strings.', 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'description' => 'A set of numbers.', 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'description' => 'A set of binary attributes.', 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', ), ), ), ), ), 'ConsumedCapacityUnits' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'UpdateTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'description' => 'The name of the table being described.', 'type' => 'string', ), 'KeySchema' => array( 'type' => 'object', 'properties' => array( 'HashKeyElement' => array( 'description' => 'A hash key element is treated as the primary key, and can be a string or a number. Single attribute primary keys have one index value. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), 'RangeKeyElement' => array( 'description' => 'A range key element is treated as a secondary key (used in conjunction with the primary key), and can be a string or a number, and is only used for hash-and-range primary keys. The value can be String, Number, StringSet, NumberSet.', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'description' => 'The AttributeName of the KeySchemaElement.', 'type' => 'string', ), 'AttributeType' => array( 'description' => 'The AttributeType of the KeySchemaElement which can be a String or a Number.', 'type' => 'string', ), ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 20, 'max_attempts' => 25, ), '__TableState' => array( 'operation' => 'DescribeTable', ), 'TableExists' => array( 'extends' => '__TableState', 'description' => 'Wait until a table exists and can be accessed', 'success.type' => 'output', 'success.path' => 'Table/TableStatus', 'success.value' => 'ACTIVE', 'ignore_errors' => array( 'ResourceNotFoundException', ), ), 'TableNotExists' => array( 'extends' => '__TableState', 'description' => 'Wait until a table is deleted', 'success.type' => 'error', 'success.value' => 'ResourceNotFoundException', ), ), ); '2012-08-10', 'endpointPrefix' => 'dynamodb', 'serviceFullName' => 'Amazon DynamoDB', 'serviceAbbreviation' => 'DynamoDB', 'serviceType' => 'json', 'jsonVersion' => '1.0', 'targetPrefix' => 'DynamoDB_20120810.', 'signatureVersion' => 'v4', 'namespace' => 'DynamoDb', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'dynamodb.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'dynamodb.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'BatchGetItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'BatchGetItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.BatchGetItem', ), 'RequestItems' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'TableName', 'key_pattern' => '/[a-zA-Z0-9_.-]+/', ), 'properties' => array( 'Keys' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'maxItems' => 100, 'items' => array( 'name' => 'Key', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'BatchWriteItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'BatchWriteItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.BatchWriteItem', ), 'RequestItems' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'minItems' => 1, 'maxItems' => 25, 'data' => array( 'shape_name' => 'TableName', 'key_pattern' => '/[a-zA-Z0-9_.-]+/', ), 'items' => array( 'name' => 'WriteRequest', 'type' => 'object', 'properties' => array( 'PutRequest' => array( 'type' => 'object', 'properties' => array( 'Item' => array( 'required' => true, 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), 'DeleteRequest' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'required' => true, 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), ), ), ), ), ), ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnItemCollectionMetrics' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', 'class' => 'ItemCollectionSizeLimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateTableOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.CreateTable', ), 'AttributeDefinitions' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'AttributeType' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'KeySchema' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'maxItems' => 2, 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'KeyType' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'LocalSecondaryIndex', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'required' => true, 'type' => 'string', 'minLength' => 3, 'maxLength' => 255, ), 'KeySchema' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'maxItems' => 2, 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'KeyType' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'Projection' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'minItems' => 1, 'maxItems' => 20, 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'GlobalSecondaryIndex', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'required' => true, 'type' => 'string', 'minLength' => 3, 'maxLength' => 255, ), 'KeySchema' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'maxItems' => 2, 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'KeyType' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'Projection' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'minItems' => 1, 'maxItems' => 20, 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), ), ), ), ), ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The operation conflicts with the resource\'s availability. For example, you attempted to recreate an existing table, or tried to delete a table currently in the CREATING state.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'The number of concurrent table requests (cumulative number of tables in the CREATING, DELETING or UPDATING state) exceeds the maximum allowed of 10. Also, for tables with secondary indexes, only one of those tables can be in the CREATING state at any point in time. Do not attempt to create more than one such table simultaneously. The total limit of tables in the ACTIVE state is 250.', 'class' => 'LimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.DeleteItem', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnItemCollectionMetrics' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A condition specified in the operation could not be evaluated.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', 'class' => 'ItemCollectionSizeLimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteTableOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.DeleteTable', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'The operation conflicts with the resource\'s availability. For example, you attempted to recreate an existing table, or tried to delete a table currently in the CREATING state.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The number of concurrent table requests (cumulative number of tables in the CREATING, DELETING or UPDATING state) exceeds the maximum allowed of 10. Also, for tables with secondary indexes, only one of those tables can be in the CREATING state at any point in time. Do not attempt to create more than one such table simultaneously. The total limit of tables in the ACTIVE state is 250.', 'class' => 'LimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTableOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.DescribeTable', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'GetItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.GetItem', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'ListTables' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListTablesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.ListTables', ), 'ExclusiveStartTableName' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'PutItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PutItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.PutItem', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Item' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnItemCollectionMetrics' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A condition specified in the operation could not be evaluated.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', 'class' => 'ItemCollectionSizeLimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'Query' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'QueryOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.Query', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'IndexName' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Select' => array( 'type' => 'string', 'location' => 'json', ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'KeyConditions' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'AttributeValueList' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeValue', 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'ScanIndexForward' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'ExclusiveStartKey' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'Scan' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ScanOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.Scan', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'AttributesToGet' => array( 'type' => 'array', 'location' => 'json', 'minItems' => 1, 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), 'Select' => array( 'type' => 'string', 'location' => 'json', ), 'ScanFilter' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'AttributeValueList' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeValue', 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ComparisonOperator' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'ExclusiveStartKey' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'TotalSegments' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 4096, ), 'Segment' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 4095, ), ), 'errorResponses' => array( array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateItem' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateItemOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.UpdateItem', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'Key' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), ), 'AttributeUpdates' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Action' => array( 'type' => 'string', ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'data' => array( 'shape_name' => 'AttributeName', ), 'properties' => array( 'Value' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_encode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_encode', ), ), ), ), ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'ReturnValues' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnConsumedCapacity' => array( 'type' => 'string', 'location' => 'json', ), 'ReturnItemCollectionMetrics' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'A condition specified in the operation could not be evaluated.', 'class' => 'ConditionalCheckFailedException', ), array( 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', 'class' => 'ProvisionedThroughputExceededException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', 'class' => 'ItemCollectionSizeLimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateTableOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'DynamoDB_20120810.UpdateTable', ), 'TableName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 255, ), 'ProvisionedThroughput' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), ), ), 'GlobalSecondaryIndexUpdates' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'GlobalSecondaryIndexUpdate', 'type' => 'object', 'properties' => array( 'Update' => array( 'type' => 'object', 'properties' => array( 'IndexName' => array( 'required' => true, 'type' => 'string', 'minLength' => 3, 'maxLength' => 255, ), 'ProvisionedThroughput' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'ReadCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), 'WriteCapacityUnits' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, ), ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The operation conflicts with the resource\'s availability. For example, you attempted to recreate an existing table, or tried to delete a table currently in the CREATING state.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The number of concurrent table requests (cumulative number of tables in the CREATING, DELETING or UPDATING state) exceeds the maximum allowed of 10. Also, for tables with secondary indexes, only one of those tables can be in the CREATING state at any point in time. Do not attempt to create more than one such table simultaneously. The total limit of tables in the ACTIVE state is 250.', 'class' => 'LimitExceededException', ), array( 'reason' => 'An error occurred on the server side.', 'class' => 'InternalServerErrorException', ), ), ), ), 'models' => array( 'BatchGetItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Responses' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), ), 'UnprocessedKeys' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'Keys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), 'AttributesToGet' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ConsumedCapacity', 'type' => 'object', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), ), 'BatchWriteItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UnprocessedItems' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'WriteRequest', 'type' => 'object', 'properties' => array( 'PutRequest' => array( 'type' => 'object', 'properties' => array( 'Item' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), ), 'DeleteRequest' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), ), ), ), ), ), 'ItemCollectionMetrics' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionMetrics', 'type' => 'object', 'properties' => array( 'ItemCollectionKey' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'SizeEstimateRangeGB' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionSizeEstimateBound', 'type' => 'numeric', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ConsumedCapacity', 'type' => 'object', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), ), 'CreateTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeDefinitions' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), ), ), ), 'TableName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'LocalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'GlobalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexStatus' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'DeleteItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), 'ItemCollectionMetrics' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'ItemCollectionKey' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'SizeEstimateRangeGB' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionSizeEstimateBound', 'type' => 'numeric', ), ), ), ), ), ), 'DeleteTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeDefinitions' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), ), ), ), 'TableName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'LocalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'GlobalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexStatus' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'DescribeTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Table' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeDefinitions' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), ), ), ), 'TableName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'LocalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'GlobalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexStatus' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'GetItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Item' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'ListTablesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableNames' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TableName', 'type' => 'string', ), ), 'LastEvaluatedTableName' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'PutItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), 'ItemCollectionMetrics' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'ItemCollectionKey' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'SizeEstimateRangeGB' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionSizeEstimateBound', 'type' => 'numeric', ), ), ), ), ), ), 'QueryOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), 'Count' => array( 'type' => 'numeric', 'location' => 'json', ), 'LastEvaluatedKey' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'ScanOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'AttributeMap', 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), ), 'Count' => array( 'type' => 'numeric', 'location' => 'json', ), 'ScannedCount' => array( 'type' => 'numeric', 'location' => 'json', ), 'LastEvaluatedKey' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'UpdateItemOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'ConsumedCapacity' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'TableName' => array( 'type' => 'string', ), 'CapacityUnits' => array( 'type' => 'numeric', ), 'Table' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), 'LocalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'CapacityUnits' => array( 'type' => 'numeric', ), ), ), ), ), ), 'ItemCollectionMetrics' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'ItemCollectionKey' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'object', 'properties' => array( 'S' => array( 'type' => 'string', ), 'N' => array( 'type' => 'string', ), 'B' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'SS' => array( 'type' => 'array', 'items' => array( 'name' => 'StringAttributeValue', 'type' => 'string', ), ), 'NS' => array( 'type' => 'array', 'items' => array( 'name' => 'NumberAttributeValue', 'type' => 'string', ), ), 'BS' => array( 'type' => 'array', 'items' => array( 'name' => 'BinaryAttributeValue', 'type' => 'string', 'filters' => array( 'base64_decode', ), ), ), ), ), ), 'SizeEstimateRangeGB' => array( 'type' => 'array', 'items' => array( 'name' => 'ItemCollectionSizeEstimateBound', 'type' => 'numeric', ), ), ), ), ), ), 'UpdateTableOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TableDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'AttributeDefinitions' => array( 'type' => 'array', 'items' => array( 'name' => 'AttributeDefinition', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), ), ), ), 'TableName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'TableStatus' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'TableSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), 'LocalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'LocalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), 'GlobalSecondaryIndexes' => array( 'type' => 'array', 'items' => array( 'name' => 'GlobalSecondaryIndexDescription', 'type' => 'object', 'properties' => array( 'IndexName' => array( 'type' => 'string', ), 'KeySchema' => array( 'type' => 'array', 'items' => array( 'name' => 'KeySchemaElement', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'KeyType' => array( 'type' => 'string', ), ), ), ), 'Projection' => array( 'type' => 'object', 'properties' => array( 'ProjectionType' => array( 'type' => 'string', ), 'NonKeyAttributes' => array( 'type' => 'array', 'items' => array( 'name' => 'NonKeyAttributeName', 'type' => 'string', ), ), ), ), 'IndexStatus' => array( 'type' => 'string', ), 'ProvisionedThroughput' => array( 'type' => 'object', 'properties' => array( 'LastIncreaseDateTime' => array( 'type' => 'string', ), 'LastDecreaseDateTime' => array( 'type' => 'string', ), 'NumberOfDecreasesToday' => array( 'type' => 'numeric', ), 'ReadCapacityUnits' => array( 'type' => 'numeric', ), 'WriteCapacityUnits' => array( 'type' => 'numeric', ), ), ), 'IndexSizeBytes' => array( 'type' => 'numeric', ), 'ItemCount' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 20, 'max_attempts' => 25, ), '__TableState' => array( 'operation' => 'DescribeTable', ), 'TableExists' => array( 'extends' => '__TableState', 'success.type' => 'output', 'success.path' => 'Table/TableStatus', 'success.value' => 'ACTIVE', 'ignore_errors' => array( 'ResourceNotFoundException', ), ), 'TableNotExists' => array( 'extends' => '__TableState', 'success.type' => 'error', 'success.value' => 'ResourceNotFoundException', ), ), ); client = $client; $this->config = $config; } /** * {@inheritdoc} */ public function doWrite($id, $data, $isDataChanged) { // Prepare the attributes $expires = time() + $this->config->get('session_lifetime'); $attributes = array( 'expires' => array( 'Value' => array( 'N' => (string) $expires ) ) ); if ($isDataChanged) { if ($data != '') { $attributes['data'] = array( 'Value' => array( 'S' => $data ) ); } else { $attributes['data'] = array( 'Action' => 'DELETE' ); } } $attributes = array_merge($attributes, $this->getExtraAttributes()); // Perform the UpdateItem command try { return (bool) $this->client->getCommand('UpdateItem', array( 'TableName' => $this->config->get('table_name'), 'Key' => $this->formatKey($id), 'AttributeUpdates' => $attributes, Ua::OPTION => Ua::SESSION ))->execute(); } catch (DynamoDbException $e) { return false; } } /** * {@inheritdoc} */ public function doDestroy($id) { try { return (bool) $this->client->getCommand('DeleteItem', array( 'TableName' => $this->config->get('table_name'), 'Key' => $this->formatKey($id), Ua::OPTION => Ua::SESSION ))->execute(); } catch (DynamoDbException $e) { return false; } } /** * Generates the correct key structure based on the key value and DynamoDB API version * * @param string $keyValue The value of the key (i.e., the session ID) * * @return array formatted key structure */ protected function formatKey($keyValue) { $keyName = ($this->client->getApiVersion() < '2012-08-10') ? 'HashKeyElement' : $this->config->get('hash_key'); return array($keyName => array('S' => $keyValue)); } /** * Allows the specific strategy to add additional attributes to update * * @return array */ abstract protected function getExtraAttributes(); } baseNamespace = $baseNamespace ?: __NAMESPACE__; $this->inflector = $inflector ?: Inflector::getDefault(); } /** * Creates a session handler locking strategy * * @param string $lockingStrategy The name if the locking strategy * @param SessionHandlerConfig $config The session handler config data * * @return LockingStrategyInterface * * @throws InvalidArgumentException If the locking strategy doesn't exist */ public function factory($lockingStrategy = null, SessionHandlerConfig $config = null) { // If the locking strategy is null, let's give it the name "null" if ($lockingStrategy === null) { $lockingStrategy = 'null'; } // Make sure the locking strategy name provided is a string if (!is_string($lockingStrategy)) { throw new InvalidArgumentException('The session locking strategy ' . 'name must be provided as a string.'); } // Determine the class name of the locking strategy class $classPath = $this->baseNamespace . '\\' . $this->inflector->camel($lockingStrategy) . 'LockingStrategy'; // Make sure the locking strategy class exists if (!class_exists($classPath)) { throw new InvalidArgumentException("There is no session locking " . "strategy named \"{$classPath}\"."); } // Call the factory on the locking strategy class to create it return new $classPath($config->get('dynamodb_client'), $config); } } client->getCommand('GetItem', array( 'TableName' => $this->config->get('table_name'), 'Key' => $this->formatKey($id), 'ConsistentRead' => (bool) $this->config->get('consistent_read'), Ua::OPTION => Ua::SESSION ))->execute(); // Get the item values $item = array(); $result = isset($result['Item']) ? $result['Item'] : array(); foreach ($result as $key => $value) { $item[$key] = current($value); } } catch (DynamoDbException $e) { $item = array(); } return $item; } /** * {@inheritdoc} */ protected function getExtraAttributes() { // @codeCoverageIgnoreStart return array(); // @codeCoverageIgnoreEnd } } addDefaults(array( 'max_lock_wait_time' => 10, 'min_lock_retry_microtime' => 10000, 'max_lock_retry_microtime' => 50000, )); parent::__construct($client, $config); } /** * {@inheritdoc} * Retries the request until the lock can be acquired */ public function doRead($id) { $item = array(); $rightNow = time(); $timeout = $rightNow + $this->config->get('max_lock_wait_time'); // Create an UpdateItem command so that a lock can be set and the item // returned (via ReturnValues) in a single, atomic operation $updateItem = $this->client->getCommand('UpdateItem', array( 'TableName' => $this->config->get('table_name'), 'Key' => $this->formatKey($id), 'Expected' => array( 'lock' => array( 'Exists' => false ) ), 'AttributeUpdates' => array( 'lock' => array( 'Value' => array( 'N' => '1' ) ) ), 'ReturnValues' => 'ALL_NEW', Ua::OPTION => Ua::SESSION )); // Acquire the lock and fetch the item data do { try { $result = $updateItem->execute(); } catch (ConditionalCheckFailedException $e) { // If lock fails, sleep and try again later usleep(rand( $this->config->get('min_lock_retry_microtime'), $this->config->get('max_lock_retry_microtime') )); $result = array(); $rightNow = time(); } catch (DynamoDbException $e) { return $item; } } while (!$result && $rightNow < $timeout); // Get the item attributes if (isset($result['Attributes'])) { foreach ($result['Attributes'] as $key => $value) { $item[$key] = current($value); } } return $item; } /** * {@inheritdoc} */ protected function getExtraAttributes() { // @codeCoverageIgnoreStart return array('lock' => array('Action' => 'DELETE')); // @codeCoverageIgnoreEnd } } get('dynamodb_client'); // Make sure locking strategy has been provided or provide a default $strategy = $config->get('locking_strategy'); if (!($strategy instanceof LockingStrategyInterface)) { $factory = new LockingStrategyFactory(); $strategy = $factory->factory($strategy, $config); } // Return an instance of the session handler return new static($client, $strategy, $config); } /** * Constructs a new DynamoDB Session Handler * * @param DynamoDbClient $client Client for doing DynamoDB operations * @param LockingStrategyInterface $strategy Locking strategy for performing session locking logic * @param SessionHandlerConfig $config Configuration options for the session handler */ public function __construct( DynamoDbClient $client, LockingStrategyInterface $strategy, SessionHandlerConfig $config ) { $this->client = $client; $this->lockingStrategy = $strategy; $this->config = $config; } /** * Destruct the session handler and make sure the session gets written * * NOTE: It is usually better practice to call `session_write_close()` manually in your application as soon as * session modifications are complete. This is especially true if session locking is enabled. * * @link http://php.net/manual/en/function.session-set-save-handler.php#refsect1-function.session-set-save-handler-notes */ public function __destruct() { session_write_close(); } /** * Register the DynamoDB session handler. * * Uses the PHP-provided method to register this class as a session handler. * * @return bool Whether or not the handler was registered */ public function register() { // Set garbage collection probability based on config $autoGarbageCollection = $this->config->get('automatic_gc') ? '1' : '0'; ini_set('session.gc_probability', $autoGarbageCollection); // Register the session handler return session_set_save_handler( array($this, 'open'), array($this, 'close'), array($this, 'read'), array($this, 'write'), array($this, 'destroy'), array($this, 'gc') ); } /** * Checks if the session is open and writable * * @return bool Whether or not the session is open for writing */ public function isSessionOpen() { return (bool) $this->openSessionId; } /** * Checks if the session has been written * * @return bool Whether or not the session has been written */ public function isSessionWritten() { return $this->sessionWritten; } /** * Creates a table in DynamoDB for session storage according to provided configuration options. * * Note: This is a one-time operation. It may be better to do this via the AWS management console ahead of time. * * @param int $readCapacityUnits RCUs for table read throughput * @param int $writeCapacityUnits WCUs table write throughput * * @return array The command result */ public function createSessionsTable($readCapacityUnits, $writeCapacityUnits) { $tableName = $this->config->get('table_name'); $hashKey = $this->config->get('hash_key'); $params = array( 'TableName' => $tableName, 'ProvisionedThroughput' => array( 'ReadCapacityUnits' => (int) $readCapacityUnits, 'WriteCapacityUnits' => (int) $writeCapacityUnits, ), Ua::OPTION => Ua::SESSION ); if ($this->client->getApiVersion() < '2012-08-10') { $params['KeySchema'] = array( 'HashKeyElement' => array( 'AttributeName' => $hashKey, 'AttributeType' => 'S', ) ); } else { $params['AttributeDefinitions'] = array( array( 'AttributeName' => $hashKey, 'AttributeType' => 'S' ) ); $params['KeySchema'] = array( array( 'AttributeName' => $hashKey, 'KeyType' => 'HASH' ) ); } $result = $this->client->getCommand('CreateTable', $params)->execute(); $this->client->waitUntil('table_exists', array('TableName' => $tableName)); return $result; } /** * Open a session for writing. Triggered by session_start() * * Part of the standard PHP session handler interface * * @param string $savePath The session save path * @param string $sessionName The session name * * @return bool Whether or not the operation succeeded */ public function open($savePath, $sessionName) { $this->savePath = $savePath; $this->sessionName = $sessionName; $this->openSessionId = session_id(); return $this->isSessionOpen(); } /** * Close a session from writing * * Part of the standard PHP session handler interface * * @return bool Success */ public function close() { // Make sure the session is unlocked and the expiration time is updated, even if the write did not occur if (!$this->isSessionWritten()) { $id = $this->formatId($this->openSessionId); $result = $this->lockingStrategy->doWrite($id, '', false); $this->sessionWritten = (bool) $result; } $this->openSessionId = null; return $this->isSessionWritten(); } /** * Read a session stored in DynamoDB * * Part of the standard PHP session handler interface * * @param string $id The session ID * * @return string The session data */ public function read($id) { // PHP expects an empty string to be returned from this method if no // data is retrieved $this->dataRead = ''; // Get session data using the selected locking strategy $item = $this->lockingStrategy->doRead($this->formatId($id)); // Return the data if it is not expired. If it is expired, remove it if (isset($item['expires']) && isset($item['data'])) { $this->dataRead = $item['data']; if ($item['expires'] <= time()) { $this->dataRead = ''; $this->destroy($id); } } return $this->dataRead; } /** * Write a session to DynamoDB * * Part of the standard PHP session handler interface * * @param string $id The session ID * @param string $data The serialized session data to write * * @return bool Whether or not the operation succeeded */ public function write($id, $data) { // Write the session data using the selected locking strategy $this->sessionWritten = $this->lockingStrategy->doWrite( $this->formatId($id), $data, ($data !== $this->dataRead) ); return $this->isSessionWritten(); } /** * Delete a session stored in DynamoDB * * Part of the standard PHP session handler interface * * @param string $id The session ID * * @return bool Whether or not the operation succeeded */ public function destroy($id) { // Delete the session data using the selected locking strategy $this->sessionWritten = $this->lockingStrategy->doDestroy($this->formatId($id)); return $this->isSessionWritten(); } /** * Triggers garbage collection on expired sessions * * Part of the standard PHP session handler interface * * @param int $maxLifetime The value of `session.gc_maxlifetime`. Ignored * * @return bool */ public function gc($maxLifetime) { try { $this->garbageCollect(); return true; } catch (\Exception $e) { return false; } } /** * Performs garbage collection on the sessions stored in the DynamoDB table * * If triggering garbage collection manually, use this method. If your garbage collection is triggered automatically * by php (not recommended), then use the `gc` method. */ public function garbageCollect() { // Get relevant configuration data $delay = (int) $this->config->get('gc_operation_delay'); $batchSize = (int) $this->config->get('gc_batch_size'); $tableName = $this->config->get('table_name'); $hashKey = $this->config->get('hash_key'); $expires = (string) time(); $isOldApi = ($this->client->getApiVersion() < '2012-08-10'); // Instantiate and configure the WriteRequestBatch object that will be deleting the expired sessions if ($delay) { $delayFunction = function () use ($delay) { sleep($delay); }; $deleteBatch = WriteRequestBatch::factory($this->client, $batchSize, $delayFunction); } else { $deleteBatch = WriteRequestBatch::factory($this->client, $batchSize); } // Setup a scan table iterator for finding expired session items $scanParams = array( 'TableName' => $tableName, 'AttributesToGet' => array( $this->config->get('hash_key') ), 'ScanFilter' => array( 'expires' => array( 'ComparisonOperator' => 'LT', 'AttributeValueList' => array( array( 'N' => $expires ) ), ), 'lock' => array( 'ComparisonOperator' => 'NULL', ) ), Ua::OPTION => Ua::SESSION ); if (!$isOldApi) { $scanParams['Select'] = 'SPECIFIC_ATTRIBUTES'; } // Create a scan table iterator for finding expired session items $tableScanner = $this->client->getIterator('Scan', $scanParams); // If a delay has been set, then attach the delay function to execute after each scan operation if (isset($delayFunction)) { $tableScanner->getEventDispatcher()->addListener('resource_iterator.after_send', $delayFunction); } // Perform scan and batch delete operations as needed $keyName = $isOldApi ? 'HashKeyElement' : $hashKey; foreach ($tableScanner as $item) { // @codeCoverageIgnoreStart $deleteBatch->add(new DeleteRequest(array($keyName => $item[$hashKey]), $tableName)); // @codeCoverageIgnoreEnd } // Delete any remaining items $deleteBatch->flush(); } /** * Prepend the session ID with the session name * * @param string $id The session ID * * @return string Prepared session ID */ protected function formatId($id) { return trim($this->sessionName . '_' . $id, '_'); } } data = $data; // Make sure the DynamoDB client has been provided if (!($this->get('dynamodb_client') instanceof DynamoDbClient)) { throw new InvalidArgumentException('The DynamoDB Session Handler ' . 'must be provided an instance of the DynamoDbClient.'); } // Merge provided data with defaults $this->addDefaults(array( 'table_name' => 'sessions', 'hash_key' => 'id', 'session_lifetime' => (int) ini_get('session.gc_maxlifetime'), 'consistent_read' => true, 'automatic_gc' => (bool) ini_get('session.gc_probability'), 'gc_batch_size' => 25, 'gc_operation_delay' => 0, )); } /** * Gets a config value if it exists, otherwise it returns null * * @param string $key The key of the config item * * @return mixed */ public function get($key) { return array_key_exists($key, $this->data) ? $this->data[$key] : null; } /** * Applies default values by merging underneath the current data * * @param array $defaults The new default data to merge underneath * * @return SessionHandlerConfig */ public function addDefaults(array $defaults) { $this->data = array_replace($defaults, $this->data); return $this; } } = 50400) { /** * @see http://php.net/manual/en/class.sessionhandlerinterface.php */ interface SessionHandlerInterface extends \SessionHandlerInterface {} } else { interface SessionHandlerInterface { public function close(); public function destroy($session_id); public function gc($maxLifetime); public function open($savePath, $sessionName); public function read($sessionId); public function write($sessionId, $sessionData); } } setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/ec2-%s.php' )) ->build(); } } get('Reservations') as $reservation) { foreach ($reservation['Instances'] as $instance) { $instance['Reservation'] = $reservation; unset($instance['Reservation']['Instances']); $instances[] = $instance; } } return $instances; } } '2013-10-15', 'endpointPrefix' => 'ec2', 'serviceFullName' => 'Amazon Elastic Compute Cloud', 'serviceAbbreviation' => 'Amazon EC2', 'serviceType' => 'query', 'signatureVersion' => 'v2', 'namespace' => 'Ec2', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'ec2.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'ec2.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'ActivateLicense' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ActivateLicense', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Capacity' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'AllocateAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AllocateAddressResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AllocateAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Domain' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AssignPrivateIpAddresses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssignPrivateIpAddresses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PrivateIpAddress', 'items' => array( 'name' => 'PrivateIpAddress', 'type' => 'string', ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AllowReassignment' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'AssociateAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssociateAddressResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssociateAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PublicIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllocationId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PrivateIpAddress' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowReassociation' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'AssociateDhcpOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssociateDhcpOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DhcpOptionsId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AssociateRouteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssociateRouteTableResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssociateRouteTable', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SubnetId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AttachInternetGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachInternetGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InternetGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AttachNetworkInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AttachNetworkInterfaceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachNetworkInterface', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DeviceIndex' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'AttachVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'attachment', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Device' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AttachVpnGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AttachVpnGatewayResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachVpnGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'AuthorizeSecurityGroupEgress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeSecurityGroupEgress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpProtocol' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FromPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ToPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CidrIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpPermissions' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'IpPermission', 'type' => 'object', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', ), 'FromPort' => array( 'type' => 'numeric', ), 'ToPort' => array( 'type' => 'numeric', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'Groups', 'items' => array( 'name' => 'Groups', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IpRange', 'type' => 'object', 'properties' => array( 'CidrIp' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'AuthorizeSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'GroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpProtocol' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FromPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ToPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CidrIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpPermissions' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'IpPermission', 'type' => 'object', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', ), 'FromPort' => array( 'type' => 'numeric', ), 'ToPort' => array( 'type' => 'numeric', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'Groups', 'items' => array( 'name' => 'Groups', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IpRange', 'type' => 'object', 'properties' => array( 'CidrIp' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'BundleInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'BundleInstanceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'BundleInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Storage' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'S3' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), 'AWSAccessKeyId' => array( 'type' => 'string', ), 'UploadPolicy' => array( 'type' => 'string', ), 'UploadPolicySignature' => array( 'type' => 'string', ), ), ), ), ), ), ), 'CancelBundleTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CancelBundleTaskResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelBundleTask', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'BundleId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CancelConversionTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelConversionTask', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ConversionTaskId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReasonMessage' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CancelExportTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelExportTask', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ExportTaskId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CancelReservedInstancesListing' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CancelReservedInstancesListingResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelReservedInstancesListing', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ReservedInstancesListingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CancelSpotInstanceRequests' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CancelSpotInstanceRequestsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelSpotInstanceRequests', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SpotInstanceRequestIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SpotInstanceRequestId', 'items' => array( 'name' => 'SpotInstanceRequestId', 'type' => 'string', ), ), ), ), 'ConfirmProductInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfirmProductInstanceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ConfirmProductInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ProductCode' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CopyImage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CopyImageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CopyImage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SourceRegion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClientToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CopySnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CopySnapshotResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CopySnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SourceRegion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceSnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateCustomerGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateCustomerGatewayResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCustomerGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PublicIp' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'sentAs' => 'IpAddress', ), 'BgpAsn' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'CreateDhcpOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateDhcpOptionsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDhcpOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DhcpConfigurations' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DhcpConfiguration', 'items' => array( 'name' => 'DhcpConfiguration', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'CreateImage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateImageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateImage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NoReboot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'VolumeType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), ), ), 'CreateInstanceExportTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateInstanceExportTaskResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateInstanceExportTask', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TargetEnvironment' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ExportToS3Task' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'ExportToS3', 'properties' => array( 'DiskImageFormat' => array( 'type' => 'string', ), 'ContainerFormat' => array( 'type' => 'string', ), 'S3Bucket' => array( 'type' => 'string', ), 'S3Prefix' => array( 'type' => 'string', ), ), ), ), ), 'CreateInternetGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateInternetGatewayResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateInternetGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'CreateKeyPair' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateKeyPairResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateKeyPair', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'KeyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateNetworkAcl' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateNetworkAclResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateNetworkAcl', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateNetworkAclEntry' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateNetworkAclEntry', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'Protocol' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleAction' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Egress' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'IcmpTypeCode' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Icmp', 'properties' => array( 'Type' => array( 'type' => 'numeric', ), 'Code' => array( 'type' => 'numeric', ), ), ), 'PortRange' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'From' => array( 'type' => 'numeric', ), 'To' => array( 'type' => 'numeric', ), ), ), ), ), 'CreateNetworkInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateNetworkInterfaceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateNetworkInterface', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'SubnetId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PrivateIpAddress' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Groups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'PrivateIpAddressSpecification', 'type' => 'object', 'properties' => array( 'PrivateIpAddress' => array( 'required' => true, 'type' => 'string', ), 'Primary' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'CreatePlacementGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreatePlacementGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Strategy' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateReservedInstancesListing' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateReservedInstancesListingResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateReservedInstancesListing', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ReservedInstancesId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'PriceSchedules' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'PriceScheduleSpecification', 'type' => 'object', 'properties' => array( 'Term' => array( 'type' => 'numeric', ), 'Price' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), ), ), ), 'ClientToken' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'GatewayId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateRouteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateRouteTableResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateRouteTable', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateSecurityGroupResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'sentAs' => 'GroupDescription', ), 'VpcId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'snapshot', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateSpotDatafeedSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateSpotDatafeedSubscriptionResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSpotDatafeedSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Prefix' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateSubnet' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateSubnetResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSubnet', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Resources' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ResourceId', 'items' => array( 'name' => 'ResourceId', 'type' => 'string', ), ), 'Tags' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tag', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), 'CreateVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'volume', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Size' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VolumeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'CreateVpc' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateVpcResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVpc', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceTenancy' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateVpnConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateVpnConnectionResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVpnConnection', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CustomerGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpnGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Options' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'StaticRoutesOnly' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'CreateVpnConnectionRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVpnConnectionRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'VpnConnectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'CreateVpnGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateVpnGatewayResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVpnGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeactivateLicense' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeactivateLicense', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Capacity' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'DeleteCustomerGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCustomerGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CustomerGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteDhcpOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDhcpOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DhcpOptionsId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteInternetGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteInternetGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InternetGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteKeyPair' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteKeyPair', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'KeyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteNetworkAcl' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteNetworkAcl', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteNetworkAclEntry' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteNetworkAclEntry', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'Egress' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DeleteNetworkInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteNetworkInterface', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeletePlacementGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeletePlacementGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteRouteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRouteTable', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'GroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteSpotDatafeedSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSpotDatafeedSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DeleteSubnet' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSubnet', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SubnetId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Resources' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ResourceId', 'items' => array( 'name' => 'ResourceId', 'type' => 'string', ), ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tag', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), 'DeleteVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVpc' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVpc', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVpnConnection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVpnConnection', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnConnectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVpnConnectionRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVpnConnectionRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'VpnConnectionId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVpnGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVpnGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeregisterImage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeregisterImage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeAccountAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAccountAttributesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAccountAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AttributeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AttributeName', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), ), ), 'DescribeAddresses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAddressesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAddresses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PublicIps' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PublicIp', 'items' => array( 'name' => 'PublicIp', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'AllocationIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AllocationId', 'items' => array( 'name' => 'AllocationId', 'type' => 'string', ), ), ), ), 'DescribeAvailabilityZones' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAvailabilityZonesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeAvailabilityZones', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ZoneNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ZoneName', 'items' => array( 'name' => 'ZoneName', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeBundleTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeBundleTasksResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeBundleTasks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'BundleIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BundleId', 'items' => array( 'name' => 'BundleId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeConversionTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeConversionTasksResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeConversionTasks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'ConversionTaskIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ConversionTaskId', 'items' => array( 'name' => 'ConversionTaskId', 'type' => 'string', ), ), ), ), 'DescribeCustomerGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeCustomerGatewaysResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCustomerGateways', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CustomerGatewayIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CustomerGatewayId', 'items' => array( 'name' => 'CustomerGatewayId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeDhcpOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeDhcpOptionsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDhcpOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DhcpOptionsIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DhcpOptionsId', 'items' => array( 'name' => 'DhcpOptionsId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeExportTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeExportTasksResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeExportTasks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ExportTaskIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ExportTaskId', 'items' => array( 'name' => 'ExportTaskId', 'type' => 'string', ), ), ), ), 'DescribeImageAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'imageAttribute', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeImageAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeImages' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeImagesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeImages', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ImageId', 'items' => array( 'name' => 'ImageId', 'type' => 'string', ), ), 'Owners' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Owner', 'items' => array( 'name' => 'Owner', 'type' => 'string', ), ), 'ExecutableUsers' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ExecutableBy', 'items' => array( 'name' => 'ExecutableBy', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeInstanceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'InstanceAttribute', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInstanceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeInstanceStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeInstanceStatusResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInstanceStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'IncludeAllInstances' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DescribeInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'DescribeInternetGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeInternetGatewaysResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInternetGateways', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InternetGatewayIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InternetGatewayId', 'items' => array( 'name' => 'InternetGatewayId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeKeyPairs' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeKeyPairsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeKeyPairs', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'KeyNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'KeyName', 'items' => array( 'name' => 'KeyName', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeLicenses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeLicensesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLicenses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LicenseId', 'items' => array( 'name' => 'LicenseId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeNetworkAcls' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeNetworkAclsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeNetworkAcls', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NetworkAclId', 'items' => array( 'name' => 'NetworkAclId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeNetworkInterfaceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeNetworkInterfaceAttributeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeNetworkInterfaceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceDestCheck' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Groups' => array( 'type' => 'string', 'location' => 'aws.query', 'sentAs' => 'GroupSet', ), 'Attachment' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeNetworkInterfaces' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeNetworkInterfacesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeNetworkInterfaces', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NetworkInterfaceId', 'items' => array( 'name' => 'NetworkInterfaceId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribePlacementGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribePlacementGroupsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribePlacementGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'GroupName', 'items' => array( 'name' => 'GroupName', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeRegions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeRegionsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeRegions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RegionNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'RegionName', 'items' => array( 'name' => 'RegionName', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeReservedInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeReservedInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ReservedInstancesIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesId', 'items' => array( 'name' => 'ReservedInstancesId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeReservedInstancesListings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeReservedInstancesListingsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedInstancesListings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ReservedInstancesId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ReservedInstancesListingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeReservedInstancesModifications' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeReservedInstancesModificationsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedInstancesModifications', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ReservedInstancesModificationIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesModificationId', 'items' => array( 'name' => 'ReservedInstancesModificationId', 'type' => 'string', ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeReservedInstancesOfferings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeReservedInstancesOfferingsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedInstancesOfferings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ReservedInstancesOfferingIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesOfferingId', 'items' => array( 'name' => 'ReservedInstancesOfferingId', 'type' => 'string', ), ), 'InstanceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'InstanceTenancy' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'IncludeMarketplace' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'MinDuration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxDuration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxInstanceCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'DescribeRouteTables' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeRouteTablesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeRouteTables', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'RouteTableId', 'items' => array( 'name' => 'RouteTableId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeSecurityGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSecurityGroupsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSecurityGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'GroupName', 'items' => array( 'name' => 'GroupName', 'type' => 'string', ), ), 'GroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'GroupId', 'items' => array( 'name' => 'GroupId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeSnapshotAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSnapshotAttributeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSnapshotAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeSnapshots' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSnapshotsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSnapshots', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SnapshotId', 'items' => array( 'name' => 'SnapshotId', 'type' => 'string', ), ), 'OwnerIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Owner', 'items' => array( 'name' => 'Owner', 'type' => 'string', ), ), 'RestorableByUserIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'RestorableBy', 'items' => array( 'name' => 'RestorableBy', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeSpotDatafeedSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSpotDatafeedSubscriptionResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSpotDatafeedSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DescribeSpotInstanceRequests' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSpotInstanceRequestsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSpotInstanceRequests', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SpotInstanceRequestIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SpotInstanceRequestId', 'items' => array( 'name' => 'SpotInstanceRequestId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeSpotPriceHistory' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSpotPriceHistoryResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSpotPriceHistory', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'InstanceTypes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceType', 'items' => array( 'name' => 'InstanceType', 'type' => 'string', ), ), 'ProductDescriptions' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ProductDescription', 'items' => array( 'name' => 'ProductDescription', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeSubnets' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeSubnetsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeSubnets', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetId', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeTagsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeTags', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeVolumeAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVolumeAttributeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVolumeAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeVolumeStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVolumeStatusResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVolumeStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VolumeId', 'items' => array( 'name' => 'VolumeId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxResults' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'DescribeVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVolumesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVolumes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VolumeId', 'items' => array( 'name' => 'VolumeId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeVpcAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVpcAttributeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVpcAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeVpcs' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVpcsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVpcs', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpcIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcId', 'items' => array( 'name' => 'VpcId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeVpnConnections' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVpnConnectionsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVpnConnections', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnConnectionIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpnConnectionId', 'items' => array( 'name' => 'VpnConnectionId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeVpnGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeVpnGatewaysResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeVpnGateways', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnGatewayIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpnGatewayId', 'items' => array( 'name' => 'VpnGatewayId', 'type' => 'string', ), ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filter', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'Value', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), ), ), 'DetachInternetGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachInternetGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InternetGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DetachNetworkInterface' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachNetworkInterface', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AttachmentId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Force' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DetachVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'attachment', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Device' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Force' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DetachVpnGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachVpnGateway', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VpnGatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DisableVgwRoutePropagation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableVgwRoutePropagation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'GatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DisassociateAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisassociateAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PublicIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AssociationId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DisassociateRouteTable' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisassociateRouteTable', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AssociationId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'EnableVgwRoutePropagation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableVgwRoutePropagation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'GatewayId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'EnableVolumeIO' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableVolumeIO', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetConsoleOutput' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetConsoleOutputResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetConsoleOutput', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetPasswordData' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetPasswordDataResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetPasswordData', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ImportInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ImportInstanceResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ImportInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LaunchSpecification' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Architecture' => array( 'type' => 'string', ), 'GroupNames' => array( 'type' => 'array', 'sentAs' => 'GroupName', 'items' => array( 'name' => 'GroupName', 'type' => 'string', ), ), 'AdditionalInfo' => array( 'type' => 'string', ), 'UserData' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'Placement' => array( 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'Tenancy' => array( 'type' => 'string', ), ), ), 'Monitoring' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'SubnetId' => array( 'type' => 'string', ), 'InstanceInitiatedShutdownBehavior' => array( 'type' => 'string', ), 'PrivateIpAddress' => array( 'type' => 'string', ), ), ), 'DiskImages' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DiskImage', 'items' => array( 'name' => 'DiskImage', 'type' => 'object', 'properties' => array( 'Image' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'required' => true, 'type' => 'string', ), 'Bytes' => array( 'required' => true, 'type' => 'numeric', ), 'ImportManifestUrl' => array( 'required' => true, 'type' => 'string', ), ), ), 'Description' => array( 'type' => 'string', ), 'Volume' => array( 'type' => 'object', 'properties' => array( 'Size' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), ), ), 'Platform' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ImportKeyPair' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ImportKeyPairResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ImportKeyPair', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'KeyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PublicKeyMaterial' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'filters' => array( 'base64_encode', ), ), ), ), 'ImportVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ImportVolumeResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ImportVolume', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Image' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Format' => array( 'required' => true, 'type' => 'string', ), 'Bytes' => array( 'required' => true, 'type' => 'numeric', ), 'ImportManifestUrl' => array( 'required' => true, 'type' => 'string', ), ), ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Volume' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Size' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), ), 'ModifyImageAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyImageAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OperationType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'UserIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'UserId', 'items' => array( 'name' => 'UserId', 'type' => 'string', ), ), 'UserGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'UserGroup', 'items' => array( 'name' => 'UserGroup', 'type' => 'string', ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ProductCode', 'items' => array( 'name' => 'ProductCode', 'type' => 'string', ), ), 'Value' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LaunchPermission' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Add' => array( 'type' => 'array', 'items' => array( 'name' => 'LaunchPermission', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'Group' => array( 'type' => 'string', ), ), ), ), 'Remove' => array( 'type' => 'array', 'items' => array( 'name' => 'LaunchPermission', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'Group' => array( 'type' => 'string', ), ), ), ), ), ), 'Description' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), ), ), 'ModifyInstanceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyInstanceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Value' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'VolumeId' => array( 'type' => 'string', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'VirtualName' => array( 'type' => 'string', ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), 'SourceDestCheck' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'DisableApiTermination' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'InstanceType' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'Kernel' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'Ramdisk' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'UserData' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'InstanceInitiatedShutdownBehavior' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'Groups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'GroupId', 'items' => array( 'name' => 'GroupId', 'type' => 'string', ), ), 'EbsOptimized' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'SriovNetSupport' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), ), ), 'ModifyNetworkInterfaceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyNetworkInterfaceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), 'SourceDestCheck' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'Groups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'Attachment' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'ModifyReservedInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ModifyReservedInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyReservedInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'ClientToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ReservedInstancesIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesId', 'items' => array( 'name' => 'ReservedInstancesId', 'type' => 'string', ), ), 'TargetConfigurations' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReservedInstancesConfigurationSetItemType', 'items' => array( 'name' => 'ReservedInstancesConfigurationSetItemType', 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), 'Platform' => array( 'type' => 'string', ), 'InstanceCount' => array( 'type' => 'numeric', ), 'InstanceType' => array( 'type' => 'string', ), ), ), ), ), ), 'ModifySnapshotAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifySnapshotAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OperationType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'UserIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'UserId', 'items' => array( 'name' => 'UserId', 'type' => 'string', ), ), 'GroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'UserGroup', 'items' => array( 'name' => 'UserGroup', 'type' => 'string', ), ), 'CreateVolumePermission' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Add' => array( 'type' => 'array', 'items' => array( 'name' => 'CreateVolumePermission', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'Group' => array( 'type' => 'string', ), ), ), ), 'Remove' => array( 'type' => 'array', 'items' => array( 'name' => 'CreateVolumePermission', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'Group' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'ModifyVolumeAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyVolumeAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AutoEnableIO' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'ModifyVpcAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyVpcAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'VpcId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EnableDnsSupport' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'EnableDnsHostnames' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), 'MonitorInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'MonitorInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'MonitorInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), 'PurchaseReservedInstancesOffering' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'PurchaseReservedInstancesOfferingResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PurchaseReservedInstancesOffering', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ReservedInstancesOfferingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'LimitPrice' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Amount' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), ), ), ), ), 'RebootInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebootInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), 'RegisterImage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RegisterImageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RegisterImage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageLocation' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Name' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Architecture' => array( 'type' => 'string', 'location' => 'aws.query', ), 'KernelId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'RamdiskId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'RootDeviceName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'VolumeType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), 'VirtualizationType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SriovNetSupport' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReleaseAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReleaseAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PublicIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllocationId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReplaceNetworkAclAssociation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplaceNetworkAclAssociationResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReplaceNetworkAclAssociation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AssociationId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReplaceNetworkAclEntry' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReplaceNetworkAclEntry', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkAclId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'Protocol' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RuleAction' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Egress' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'CidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'IcmpTypeCode' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Icmp', 'properties' => array( 'Type' => array( 'type' => 'numeric', ), 'Code' => array( 'type' => 'numeric', ), ), ), 'PortRange' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'From' => array( 'type' => 'numeric', ), 'To' => array( 'type' => 'numeric', ), ), ), ), ), 'ReplaceRoute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReplaceRoute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationCidrBlock' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'GatewayId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReplaceRouteTableAssociation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplaceRouteTableAssociationResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReplaceRouteTableAssociation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AssociationId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RouteTableId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReportInstanceStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReportInstanceStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Instances' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'ReasonCodes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReasonCode', 'items' => array( 'name' => 'ReasonCode', 'type' => 'string', ), ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'RequestSpotInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RequestSpotInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RequestSpotInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SpotPrice' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstanceCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Type' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ValidFrom' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'ValidUntil' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'LaunchGroup' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZoneGroup' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LaunchSpecification' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'ImageId' => array( 'type' => 'string', ), 'KeyName' => array( 'type' => 'string', ), 'UserData' => array( 'type' => 'string', ), 'AddressingType' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'Placement' => array( 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), ), ), 'KernelId' => array( 'type' => 'string', ), 'RamdiskId' => array( 'type' => 'string', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'VolumeType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), 'Monitoring' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'SubnetId' => array( 'type' => 'string', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'NetworkInterface', 'items' => array( 'name' => 'NetworkInterface', 'type' => 'object', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', ), 'DeviceIndex' => array( 'type' => 'numeric', ), 'SubnetId' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'PrivateIpAddress' => array( 'type' => 'string', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'items' => array( 'name' => 'PrivateIpAddressSpecification', 'type' => 'object', 'properties' => array( 'PrivateIpAddress' => array( 'required' => true, 'type' => 'string', ), 'Primary' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'SecurityGroupIds' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroup', 'items' => array( 'name' => 'SecurityGroup', 'type' => 'string', ), ), ), ), ), ), 'ResetImageAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetImageAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ResetInstanceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetInstanceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ResetNetworkInterfaceAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetNetworkInterfaceAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceDestCheck' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ResetSnapshotAttribute' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetSnapshotAttribute', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'SnapshotId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attribute' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'RevokeSecurityGroupEgress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeSecurityGroupEgress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpProtocol' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FromPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ToPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CidrIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpPermissions' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'IpPermission', 'type' => 'object', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', ), 'FromPort' => array( 'type' => 'numeric', ), 'ToPort' => array( 'type' => 'numeric', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'Groups', 'items' => array( 'name' => 'Groups', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IpRange', 'type' => 'object', 'properties' => array( 'CidrIp' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'RevokeSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'GroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'GroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceSecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpProtocol' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FromPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ToPort' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CidrIp' => array( 'type' => 'string', 'location' => 'aws.query', ), 'IpPermissions' => array( 'type' => 'array', 'location' => 'aws.query', 'items' => array( 'name' => 'IpPermission', 'type' => 'object', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', ), 'FromPort' => array( 'type' => 'numeric', ), 'ToPort' => array( 'type' => 'numeric', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'Groups', 'items' => array( 'name' => 'Groups', 'type' => 'object', 'properties' => array( 'UserId' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IpRange', 'type' => 'object', 'properties' => array( 'CidrIp' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'RunInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'reservation', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RunInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ImageId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MinCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'KeyName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroup', 'items' => array( 'name' => 'SecurityGroup', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'UserData' => array( 'type' => 'string', 'location' => 'aws.query', ), 'InstanceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Placement' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'Tenancy' => array( 'type' => 'string', ), ), ), 'KernelId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'RamdiskId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'BlockDeviceMapping', 'items' => array( 'name' => 'BlockDeviceMapping', 'type' => 'object', 'properties' => array( 'VirtualName' => array( 'type' => 'string', ), 'DeviceName' => array( 'type' => 'string', ), 'Ebs' => array( 'type' => 'object', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', ), 'VolumeSize' => array( 'type' => 'numeric', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'VolumeType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), ), ), 'NoDevice' => array( 'type' => 'string', ), ), ), ), 'Monitoring' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'SubnetId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DisableApiTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceInitiatedShutdownBehavior' => array( 'type' => 'string', 'location' => 'aws.query', ), 'License' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Pool' => array( 'type' => 'string', ), ), ), 'PrivateIpAddress' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClientToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AdditionalInfo' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NetworkInterfaces' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'NetworkInterface', 'items' => array( 'name' => 'NetworkInterface', 'type' => 'object', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', ), 'DeviceIndex' => array( 'type' => 'numeric', ), 'SubnetId' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'PrivateIpAddress' => array( 'type' => 'string', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'PrivateIpAddressesSet', 'items' => array( 'name' => 'PrivateIpAddressesSet', 'type' => 'object', 'properties' => array( 'PrivateIpAddress' => array( 'required' => true, 'type' => 'string', ), 'Primary' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'StartInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'StartInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'StartInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'AdditionalInfo' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'StopInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'StopInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'StopInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), 'Force' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'TerminateInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'TerminateInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'TerminateInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), 'UnassignPrivateIpAddresses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UnassignPrivateIpAddresses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PrivateIpAddresses' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PrivateIpAddress', 'items' => array( 'name' => 'PrivateIpAddress', 'type' => 'string', ), ), ), ), 'UnmonitorInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UnmonitorInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UnmonitorInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-10-15', ), 'DryRun' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'InstanceId', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'AllocateAddressResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'publicIp', ), 'Domain' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'domain', ), 'AllocationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'allocationId', ), ), ), 'AssociateAddressResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AssociationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'associationId', ), ), ), 'AssociateRouteTableResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AssociationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'associationId', ), ), ), 'AttachNetworkInterfaceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'attachmentId', ), ), ), 'attachment' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeId', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'instanceId', ), 'Device' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'device', ), 'State' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'location' => 'xml', 'sentAs' => 'deleteOnTermination', ), ), ), 'AttachVpnGatewayResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpcAttachment' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'attachment', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), 'BundleInstanceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'BundleTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'bundleInstanceTask', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'BundleId' => array( 'type' => 'string', 'sentAs' => 'bundleId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StartTime' => array( 'type' => 'string', 'sentAs' => 'startTime', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Storage' => array( 'type' => 'object', 'sentAs' => 'storage', 'properties' => array( 'S3' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'AWSAccessKeyId' => array( 'type' => 'string', ), 'UploadPolicy' => array( 'type' => 'string', 'sentAs' => 'uploadPolicy', ), 'UploadPolicySignature' => array( 'type' => 'string', 'sentAs' => 'uploadPolicySignature', ), ), ), ), ), 'Progress' => array( 'type' => 'string', 'sentAs' => 'progress', ), 'BundleTaskError' => array( 'type' => 'object', 'sentAs' => 'error', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), 'CancelBundleTaskResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'BundleTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'bundleInstanceTask', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'BundleId' => array( 'type' => 'string', 'sentAs' => 'bundleId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StartTime' => array( 'type' => 'string', 'sentAs' => 'startTime', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Storage' => array( 'type' => 'object', 'sentAs' => 'storage', 'properties' => array( 'S3' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'AWSAccessKeyId' => array( 'type' => 'string', ), 'UploadPolicy' => array( 'type' => 'string', 'sentAs' => 'uploadPolicy', ), 'UploadPolicySignature' => array( 'type' => 'string', 'sentAs' => 'uploadPolicySignature', ), ), ), ), ), 'Progress' => array( 'type' => 'string', 'sentAs' => 'progress', ), 'BundleTaskError' => array( 'type' => 'object', 'sentAs' => 'error', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), 'CancelReservedInstancesListingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesListings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesListingsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesListingId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesListingId', ), 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'CreateDate' => array( 'type' => 'string', 'sentAs' => 'createDate', ), 'UpdateDate' => array( 'type' => 'string', 'sentAs' => 'updateDate', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceCounts' => array( 'type' => 'array', 'sentAs' => 'instanceCounts', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), ), ), ), 'PriceSchedules' => array( 'type' => 'array', 'sentAs' => 'priceSchedules', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Term' => array( 'type' => 'numeric', 'sentAs' => 'term', ), 'Price' => array( 'type' => 'numeric', 'sentAs' => 'price', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'Active' => array( 'type' => 'boolean', 'sentAs' => 'active', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), ), ), ), ), ), 'CancelSpotInstanceRequestsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CancelledSpotInstanceRequests' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'spotInstanceRequestSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), 'ConfirmProductInstanceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OwnerId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'ownerId', ), ), ), 'CopyImageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ImageId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'imageId', ), ), ), 'CopySnapshotResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'snapshotId', ), ), ), 'CreateCustomerGatewayResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CustomerGateway' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'customerGateway', 'properties' => array( 'CustomerGatewayId' => array( 'type' => 'string', 'sentAs' => 'customerGatewayId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'IpAddress' => array( 'type' => 'string', 'sentAs' => 'ipAddress', ), 'BgpAsn' => array( 'type' => 'string', 'sentAs' => 'bgpAsn', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'CreateDhcpOptionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DhcpOptions' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'dhcpOptions', 'properties' => array( 'DhcpOptionsId' => array( 'type' => 'string', 'sentAs' => 'dhcpOptionsId', ), 'DhcpConfigurations' => array( 'type' => 'array', 'sentAs' => 'dhcpConfigurationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'valueSet', 'items' => array( 'name' => 'item', 'type' => 'string', 'sentAs' => 'item', ), ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'CreateImageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ImageId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'imageId', ), ), ), 'CreateInstanceExportTaskResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ExportTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'exportTask', 'properties' => array( 'ExportTaskId' => array( 'type' => 'string', 'sentAs' => 'exportTaskId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceExportDetails' => array( 'type' => 'object', 'sentAs' => 'instanceExport', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'TargetEnvironment' => array( 'type' => 'string', 'sentAs' => 'targetEnvironment', ), ), ), 'ExportToS3Task' => array( 'type' => 'object', 'sentAs' => 'exportToS3', 'properties' => array( 'DiskImageFormat' => array( 'type' => 'string', 'sentAs' => 'diskImageFormat', ), 'ContainerFormat' => array( 'type' => 'string', 'sentAs' => 'containerFormat', ), 'S3Bucket' => array( 'type' => 'string', 'sentAs' => 's3Bucket', ), 'S3Key' => array( 'type' => 'string', 'sentAs' => 's3Key', ), ), ), ), ), ), ), 'CreateInternetGatewayResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InternetGateway' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'internetGateway', 'properties' => array( 'InternetGatewayId' => array( 'type' => 'string', 'sentAs' => 'internetGatewayId', ), 'Attachments' => array( 'type' => 'array', 'sentAs' => 'attachmentSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'CreateKeyPairResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'KeyName' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyName', ), 'KeyFingerprint' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyFingerprint', ), 'KeyMaterial' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyMaterial', ), ), ), 'CreateNetworkAclResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkAcl' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'networkAcl', 'properties' => array( 'NetworkAclId' => array( 'type' => 'string', 'sentAs' => 'networkAclId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'IsDefault' => array( 'type' => 'boolean', 'sentAs' => 'default', ), 'Entries' => array( 'type' => 'array', 'sentAs' => 'entrySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RuleNumber' => array( 'type' => 'numeric', 'sentAs' => 'ruleNumber', ), 'Protocol' => array( 'type' => 'string', 'sentAs' => 'protocol', ), 'RuleAction' => array( 'type' => 'string', 'sentAs' => 'ruleAction', ), 'Egress' => array( 'type' => 'boolean', 'sentAs' => 'egress', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'IcmpTypeCode' => array( 'type' => 'object', 'sentAs' => 'icmpTypeCode', 'properties' => array( 'Type' => array( 'type' => 'numeric', 'sentAs' => 'type', ), 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), ), ), 'PortRange' => array( 'type' => 'object', 'sentAs' => 'portRange', 'properties' => array( 'From' => array( 'type' => 'numeric', 'sentAs' => 'from', ), 'To' => array( 'type' => 'numeric', 'sentAs' => 'to', ), ), ), ), ), ), 'Associations' => array( 'type' => 'array', 'sentAs' => 'associationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkAclAssociationId' => array( 'type' => 'string', 'sentAs' => 'networkAclAssociationId', ), 'NetworkAclId' => array( 'type' => 'string', 'sentAs' => 'networkAclId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'CreateNetworkInterfaceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkInterface' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'networkInterface', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'RequesterId' => array( 'type' => 'string', 'sentAs' => 'requesterId', ), 'RequesterManaged' => array( 'type' => 'boolean', 'sentAs' => 'requesterManaged', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'MacAddress' => array( 'type' => 'string', 'sentAs' => 'macAddress', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), ), ), 'TagSet' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), ), ), ), ), ), ), ), ), ), 'CreateReservedInstancesListingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesListings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesListingsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesListingId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesListingId', ), 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'CreateDate' => array( 'type' => 'string', 'sentAs' => 'createDate', ), 'UpdateDate' => array( 'type' => 'string', 'sentAs' => 'updateDate', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceCounts' => array( 'type' => 'array', 'sentAs' => 'instanceCounts', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), ), ), ), 'PriceSchedules' => array( 'type' => 'array', 'sentAs' => 'priceSchedules', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Term' => array( 'type' => 'numeric', 'sentAs' => 'term', ), 'Price' => array( 'type' => 'numeric', 'sentAs' => 'price', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'Active' => array( 'type' => 'boolean', 'sentAs' => 'active', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), ), ), ), ), ), 'CreateRouteTableResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RouteTable' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'routeTable', 'properties' => array( 'RouteTableId' => array( 'type' => 'string', 'sentAs' => 'routeTableId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Routes' => array( 'type' => 'array', 'sentAs' => 'routeSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DestinationCidrBlock' => array( 'type' => 'string', 'sentAs' => 'destinationCidrBlock', ), 'GatewayId' => array( 'type' => 'string', 'sentAs' => 'gatewayId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Associations' => array( 'type' => 'array', 'sentAs' => 'associationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RouteTableAssociationId' => array( 'type' => 'string', 'sentAs' => 'routeTableAssociationId', ), 'RouteTableId' => array( 'type' => 'string', 'sentAs' => 'routeTableId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'Main' => array( 'type' => 'boolean', 'sentAs' => 'main', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'PropagatingVgws' => array( 'type' => 'array', 'sentAs' => 'propagatingVgwSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GatewayId' => array( 'type' => 'string', 'sentAs' => 'gatewayId', ), ), ), ), ), ), ), ), 'CreateSecurityGroupResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GroupId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'groupId', ), ), ), 'snapshot' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'snapshotId', ), 'VolumeId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeId', ), 'State' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'status', ), 'StartTime' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'startTime', ), 'Progress' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'progress', ), 'OwnerId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'ownerId', ), 'Description' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'description', ), 'VolumeSize' => array( 'type' => 'numeric', 'location' => 'xml', 'sentAs' => 'volumeSize', ), 'OwnerAlias' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'ownerAlias', ), 'Tags' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), 'CreateSpotDatafeedSubscriptionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotDatafeedSubscription' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'spotDatafeedSubscription', 'properties' => array( 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Fault' => array( 'type' => 'object', 'sentAs' => 'fault', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), 'CreateSubnetResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subnet' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'subnet', 'properties' => array( 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'AvailableIpAddressCount' => array( 'type' => 'numeric', 'sentAs' => 'availableIpAddressCount', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'DefaultForAz' => array( 'type' => 'boolean', 'sentAs' => 'defaultForAz', ), 'MapPublicIpOnLaunch' => array( 'type' => 'boolean', 'sentAs' => 'mapPublicIpOnLaunch', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'volume' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeId', ), 'Size' => array( 'type' => 'numeric', 'location' => 'xml', 'sentAs' => 'size', ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'snapshotId', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'availabilityZone', ), 'State' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'status', ), 'CreateTime' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'createTime', ), 'Attachments' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'attachmentSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Device' => array( 'type' => 'string', 'sentAs' => 'device', ), 'State' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), 'Tags' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'VolumeType' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'xml', 'sentAs' => 'iops', ), ), ), 'CreateVpcResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Vpc' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'vpc', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'DhcpOptionsId' => array( 'type' => 'string', 'sentAs' => 'dhcpOptionsId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'InstanceTenancy' => array( 'type' => 'string', 'sentAs' => 'instanceTenancy', ), 'IsDefault' => array( 'type' => 'boolean', 'sentAs' => 'isDefault', ), ), ), ), ), 'CreateVpnConnectionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpnConnection' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'vpnConnection', 'properties' => array( 'VpnConnectionId' => array( 'type' => 'string', 'sentAs' => 'vpnConnectionId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'CustomerGatewayConfiguration' => array( 'type' => 'string', 'sentAs' => 'customerGatewayConfiguration', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'CustomerGatewayId' => array( 'type' => 'string', 'sentAs' => 'customerGatewayId', ), 'VpnGatewayId' => array( 'type' => 'string', 'sentAs' => 'vpnGatewayId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'VgwTelemetry' => array( 'type' => 'array', 'sentAs' => 'vgwTelemetry', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'OutsideIpAddress' => array( 'type' => 'string', 'sentAs' => 'outsideIpAddress', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'LastStatusChange' => array( 'type' => 'string', 'sentAs' => 'lastStatusChange', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'AcceptedRouteCount' => array( 'type' => 'numeric', 'sentAs' => 'acceptedRouteCount', ), ), ), ), 'Options' => array( 'type' => 'object', 'sentAs' => 'options', 'properties' => array( 'StaticRoutesOnly' => array( 'type' => 'boolean', 'sentAs' => 'staticRoutesOnly', ), ), ), 'Routes' => array( 'type' => 'array', 'sentAs' => 'routes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DestinationCidrBlock' => array( 'type' => 'string', 'sentAs' => 'destinationCidrBlock', ), 'Source' => array( 'type' => 'string', 'sentAs' => 'source', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), ), ), 'CreateVpnGatewayResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpnGateway' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'vpnGateway', 'properties' => array( 'VpnGatewayId' => array( 'type' => 'string', 'sentAs' => 'vpnGatewayId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'VpcAttachments' => array( 'type' => 'array', 'sentAs' => 'attachments', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'DescribeAccountAttributesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccountAttributes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'accountAttributeSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'AttributeName' => array( 'type' => 'string', 'sentAs' => 'attributeName', ), 'AttributeValues' => array( 'type' => 'array', 'sentAs' => 'attributeValueSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'AttributeValue' => array( 'type' => 'string', 'sentAs' => 'attributeValue', ), ), ), ), ), ), ), ), ), 'DescribeAddressesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Addresses' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'addressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), 'Domain' => array( 'type' => 'string', 'sentAs' => 'domain', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'NetworkInterfaceOwnerId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceOwnerId', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), ), ), ), ), ), 'DescribeAvailabilityZonesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'availabilityZoneInfo', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ZoneName' => array( 'type' => 'string', 'sentAs' => 'zoneName', ), 'State' => array( 'type' => 'string', 'sentAs' => 'zoneState', ), 'RegionName' => array( 'type' => 'string', 'sentAs' => 'regionName', ), 'Messages' => array( 'type' => 'array', 'sentAs' => 'messageSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), ), ), 'DescribeBundleTasksResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'BundleTasks' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'bundleInstanceTasksSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'BundleId' => array( 'type' => 'string', 'sentAs' => 'bundleId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StartTime' => array( 'type' => 'string', 'sentAs' => 'startTime', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Storage' => array( 'type' => 'object', 'sentAs' => 'storage', 'properties' => array( 'S3' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'AWSAccessKeyId' => array( 'type' => 'string', ), 'UploadPolicy' => array( 'type' => 'string', 'sentAs' => 'uploadPolicy', ), 'UploadPolicySignature' => array( 'type' => 'string', 'sentAs' => 'uploadPolicySignature', ), ), ), ), ), 'Progress' => array( 'type' => 'string', 'sentAs' => 'progress', ), 'BundleTaskError' => array( 'type' => 'object', 'sentAs' => 'error', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), ), 'DescribeConversionTasksResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ConversionTasks' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'conversionTasks', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ConversionTaskId' => array( 'type' => 'string', 'sentAs' => 'conversionTaskId', ), 'ExpirationTime' => array( 'type' => 'string', 'sentAs' => 'expirationTime', ), 'ImportInstance' => array( 'type' => 'object', 'sentAs' => 'importInstance', 'properties' => array( 'Volumes' => array( 'type' => 'array', 'sentAs' => 'volumes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), 'ImportVolume' => array( 'type' => 'object', 'sentAs' => 'importVolume', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), ), ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeCustomerGatewaysResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CustomerGateways' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'customerGatewaySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'CustomerGatewayId' => array( 'type' => 'string', 'sentAs' => 'customerGatewayId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'IpAddress' => array( 'type' => 'string', 'sentAs' => 'ipAddress', ), 'BgpAsn' => array( 'type' => 'string', 'sentAs' => 'bgpAsn', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeDhcpOptionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DhcpOptions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'dhcpOptionsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DhcpOptionsId' => array( 'type' => 'string', 'sentAs' => 'dhcpOptionsId', ), 'DhcpConfigurations' => array( 'type' => 'array', 'sentAs' => 'dhcpConfigurationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Values' => array( 'type' => 'array', 'sentAs' => 'valueSet', 'items' => array( 'name' => 'item', 'type' => 'string', 'sentAs' => 'item', ), ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeExportTasksResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ExportTasks' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'exportTaskSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ExportTaskId' => array( 'type' => 'string', 'sentAs' => 'exportTaskId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceExportDetails' => array( 'type' => 'object', 'sentAs' => 'instanceExport', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'TargetEnvironment' => array( 'type' => 'string', 'sentAs' => 'targetEnvironment', ), ), ), 'ExportToS3Task' => array( 'type' => 'object', 'sentAs' => 'exportToS3', 'properties' => array( 'DiskImageFormat' => array( 'type' => 'string', 'sentAs' => 'diskImageFormat', ), 'ContainerFormat' => array( 'type' => 'string', 'sentAs' => 'containerFormat', ), 'S3Bucket' => array( 'type' => 'string', 'sentAs' => 's3Bucket', ), 'S3Key' => array( 'type' => 'string', 'sentAs' => 's3Key', ), ), ), ), ), ), ), ), 'imageAttribute' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ImageId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'imageId', ), 'LaunchPermissions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'launchPermission', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'UserId' => array( 'type' => 'string', 'sentAs' => 'userId', ), 'Group' => array( 'type' => 'string', 'sentAs' => 'group', ), ), ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'KernelId' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'kernel', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'RamdiskId' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'ramdisk', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'Description' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'description', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'SriovNetSupport' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'sriovNetSupport', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'sentAs' => 'virtualName', ), 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), 'NoDevice' => array( 'type' => 'string', 'sentAs' => 'noDevice', ), ), ), ), ), ), 'DescribeImagesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Images' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'imagesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'ImageLocation' => array( 'type' => 'string', 'sentAs' => 'imageLocation', ), 'State' => array( 'type' => 'string', 'sentAs' => 'imageState', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'imageOwnerId', ), 'Public' => array( 'type' => 'boolean', 'sentAs' => 'isPublic', ), 'ProductCodes' => array( 'type' => 'array', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'Architecture' => array( 'type' => 'string', 'sentAs' => 'architecture', ), 'ImageType' => array( 'type' => 'string', 'sentAs' => 'imageType', ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'SriovNetSupport' => array( 'type' => 'string', 'sentAs' => 'sriovNetSupport', ), 'StateReason' => array( 'type' => 'object', 'sentAs' => 'stateReason', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'ImageOwnerAlias' => array( 'type' => 'string', 'sentAs' => 'imageOwnerAlias', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'RootDeviceType' => array( 'type' => 'string', 'sentAs' => 'rootDeviceType', ), 'RootDeviceName' => array( 'type' => 'string', 'sentAs' => 'rootDeviceName', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'sentAs' => 'virtualName', ), 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), 'NoDevice' => array( 'type' => 'string', 'sentAs' => 'noDevice', ), ), ), ), 'VirtualizationType' => array( 'type' => 'string', 'sentAs' => 'virtualizationType', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'Hypervisor' => array( 'type' => 'string', 'sentAs' => 'hypervisor', ), ), ), ), ), ), 'InstanceAttribute' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'instanceId', ), 'InstanceType' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'instanceType', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'KernelId' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'kernel', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'RamdiskId' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'ramdisk', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'UserData' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'userData', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'DisableApiTermination' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'disableApiTermination', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'InstanceInitiatedShutdownBehavior' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'instanceInitiatedShutdownBehavior', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'RootDeviceName' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'rootDeviceName', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'BlockDeviceMappings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'EbsOptimized' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'ebsOptimized', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'SriovNetSupport' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'sriovNetSupport', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), 'DescribeInstanceStatusResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceStatuses' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instanceStatusSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Events' => array( 'type' => 'array', 'sentAs' => 'eventsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'NotBefore' => array( 'type' => 'string', 'sentAs' => 'notBefore', ), 'NotAfter' => array( 'type' => 'string', 'sentAs' => 'notAfter', ), ), ), ), 'InstanceState' => array( 'type' => 'object', 'sentAs' => 'instanceState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'SystemStatus' => array( 'type' => 'object', 'sentAs' => 'systemStatus', 'properties' => array( 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'Details' => array( 'type' => 'array', 'sentAs' => 'details', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'ImpairedSince' => array( 'type' => 'string', 'sentAs' => 'impairedSince', ), ), ), ), ), ), 'InstanceStatus' => array( 'type' => 'object', 'sentAs' => 'instanceStatus', 'properties' => array( 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'Details' => array( 'type' => 'array', 'sentAs' => 'details', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'ImpairedSince' => array( 'type' => 'string', 'sentAs' => 'impairedSince', ), ), ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Reservations' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservationId' => array( 'type' => 'string', 'sentAs' => 'reservationId', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'RequesterId' => array( 'type' => 'string', 'sentAs' => 'requesterId', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Instances' => array( 'type' => 'array', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'State' => array( 'type' => 'object', 'sentAs' => 'instanceState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'dnsName', ), 'StateTransitionReason' => array( 'type' => 'string', 'sentAs' => 'reason', ), 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'AmiLaunchIndex' => array( 'type' => 'numeric', 'sentAs' => 'amiLaunchIndex', ), 'ProductCodes' => array( 'type' => 'array', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'LaunchTime' => array( 'type' => 'string', 'sentAs' => 'launchTime', ), 'Placement' => array( 'type' => 'object', 'sentAs' => 'placement', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'Tenancy' => array( 'type' => 'string', 'sentAs' => 'tenancy', ), ), ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Monitoring' => array( 'type' => 'object', 'sentAs' => 'monitoring', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PublicIpAddress' => array( 'type' => 'string', 'sentAs' => 'ipAddress', ), 'StateReason' => array( 'type' => 'object', 'sentAs' => 'stateReason', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'Architecture' => array( 'type' => 'string', 'sentAs' => 'architecture', ), 'RootDeviceType' => array( 'type' => 'string', 'sentAs' => 'rootDeviceType', ), 'RootDeviceName' => array( 'type' => 'string', 'sentAs' => 'rootDeviceName', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), ), ), 'VirtualizationType' => array( 'type' => 'string', 'sentAs' => 'virtualizationType', ), 'InstanceLifecycle' => array( 'type' => 'string', 'sentAs' => 'instanceLifecycle', ), 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'License' => array( 'type' => 'object', 'sentAs' => 'license', 'properties' => array( 'Pool' => array( 'type' => 'string', 'sentAs' => 'pool', ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Hypervisor' => array( 'type' => 'string', 'sentAs' => 'hypervisor', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'publicDnsName', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'publicDnsName', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), ), ), ), ), ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'sentAs' => 'iamInstanceProfile', 'properties' => array( 'Arn' => array( 'type' => 'string', 'sentAs' => 'arn', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'sentAs' => 'ebsOptimized', ), 'SriovNetSupport' => array( 'type' => 'string', 'sentAs' => 'sriovNetSupport', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeInternetGatewaysResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InternetGateways' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'internetGatewaySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InternetGatewayId' => array( 'type' => 'string', 'sentAs' => 'internetGatewayId', ), 'Attachments' => array( 'type' => 'array', 'sentAs' => 'attachmentSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeKeyPairsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'KeyPairs' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'keySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'KeyFingerprint' => array( 'type' => 'string', 'sentAs' => 'keyFingerprint', ), ), ), ), ), ), 'DescribeLicensesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Licenses' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'licenseSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'LicenseId' => array( 'type' => 'string', 'sentAs' => 'licenseId', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'Pool' => array( 'type' => 'string', 'sentAs' => 'pool', ), 'Capacities' => array( 'type' => 'array', 'sentAs' => 'capacitySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Capacity' => array( 'type' => 'numeric', 'sentAs' => 'capacity', ), 'InstanceCapacity' => array( 'type' => 'numeric', 'sentAs' => 'instanceCapacity', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'EarliestAllowedDeactivationTime' => array( 'type' => 'string', 'sentAs' => 'earliestAllowedDeactivationTime', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeNetworkAclsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkAcls' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'networkAclSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkAclId' => array( 'type' => 'string', 'sentAs' => 'networkAclId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'IsDefault' => array( 'type' => 'boolean', 'sentAs' => 'default', ), 'Entries' => array( 'type' => 'array', 'sentAs' => 'entrySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RuleNumber' => array( 'type' => 'numeric', 'sentAs' => 'ruleNumber', ), 'Protocol' => array( 'type' => 'string', 'sentAs' => 'protocol', ), 'RuleAction' => array( 'type' => 'string', 'sentAs' => 'ruleAction', ), 'Egress' => array( 'type' => 'boolean', 'sentAs' => 'egress', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'IcmpTypeCode' => array( 'type' => 'object', 'sentAs' => 'icmpTypeCode', 'properties' => array( 'Type' => array( 'type' => 'numeric', 'sentAs' => 'type', ), 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), ), ), 'PortRange' => array( 'type' => 'object', 'sentAs' => 'portRange', 'properties' => array( 'From' => array( 'type' => 'numeric', 'sentAs' => 'from', ), 'To' => array( 'type' => 'numeric', 'sentAs' => 'to', ), ), ), ), ), ), 'Associations' => array( 'type' => 'array', 'sentAs' => 'associationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkAclAssociationId' => array( 'type' => 'string', 'sentAs' => 'networkAclAssociationId', ), 'NetworkAclId' => array( 'type' => 'string', 'sentAs' => 'networkAclId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeNetworkInterfaceAttributeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'networkInterfaceId', ), 'Description' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'description', 'properties' => array( 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), 'SourceDestCheck' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'sourceDestCheck', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'Groups' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), ), 'DescribeNetworkInterfacesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NetworkInterfaces' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'RequesterId' => array( 'type' => 'string', 'sentAs' => 'requesterId', ), 'RequesterManaged' => array( 'type' => 'boolean', 'sentAs' => 'requesterManaged', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'MacAddress' => array( 'type' => 'string', 'sentAs' => 'macAddress', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), ), ), 'TagSet' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), 'AllocationId' => array( 'type' => 'string', 'sentAs' => 'allocationId', ), 'AssociationId' => array( 'type' => 'string', 'sentAs' => 'associationId', ), ), ), ), ), ), ), ), ), ), ), 'DescribePlacementGroupsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PlacementGroups' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'placementGroupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'Strategy' => array( 'type' => 'string', 'sentAs' => 'strategy', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), 'DescribeRegionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Regions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'regionInfo', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RegionName' => array( 'type' => 'string', 'sentAs' => 'regionName', ), 'Endpoint' => array( 'type' => 'string', 'sentAs' => 'regionEndpoint', ), ), ), ), ), ), 'DescribeReservedInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Start' => array( 'type' => 'string', 'sentAs' => 'start', ), 'End' => array( 'type' => 'string', 'sentAs' => 'end', ), 'Duration' => array( 'type' => 'numeric', 'sentAs' => 'duration', ), 'UsagePrice' => array( 'type' => 'numeric', 'sentAs' => 'usagePrice', ), 'FixedPrice' => array( 'type' => 'numeric', 'sentAs' => 'fixedPrice', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'InstanceTenancy' => array( 'type' => 'string', 'sentAs' => 'instanceTenancy', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'OfferingType' => array( 'type' => 'string', 'sentAs' => 'offeringType', ), 'RecurringCharges' => array( 'type' => 'array', 'sentAs' => 'recurringCharges', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Frequency' => array( 'type' => 'string', 'sentAs' => 'frequency', ), 'Amount' => array( 'type' => 'numeric', 'sentAs' => 'amount', ), ), ), ), ), ), ), ), ), 'DescribeReservedInstancesListingsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesListings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesListingsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesListingId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesListingId', ), 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'CreateDate' => array( 'type' => 'string', 'sentAs' => 'createDate', ), 'UpdateDate' => array( 'type' => 'string', 'sentAs' => 'updateDate', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'InstanceCounts' => array( 'type' => 'array', 'sentAs' => 'instanceCounts', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), ), ), ), 'PriceSchedules' => array( 'type' => 'array', 'sentAs' => 'priceSchedules', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Term' => array( 'type' => 'numeric', 'sentAs' => 'term', ), 'Price' => array( 'type' => 'numeric', 'sentAs' => 'price', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'Active' => array( 'type' => 'boolean', 'sentAs' => 'active', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), ), ), ), ), ), 'DescribeReservedInstancesModificationsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesModifications' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesModificationsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesModificationId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesModificationId', ), 'ReservedInstancesIds' => array( 'type' => 'array', 'sentAs' => 'reservedInstancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), ), ), ), 'ModificationResults' => array( 'type' => 'array', 'sentAs' => 'modificationResultSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesId', ), 'TargetConfiguration' => array( 'type' => 'object', 'sentAs' => 'targetConfiguration', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'InstanceCount' => array( 'type' => 'numeric', 'sentAs' => 'instanceCount', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), ), ), ), ), ), 'CreateDate' => array( 'type' => 'string', 'sentAs' => 'createDate', ), 'UpdateDate' => array( 'type' => 'string', 'sentAs' => 'updateDate', ), 'EffectiveDate' => array( 'type' => 'string', 'sentAs' => 'effectiveDate', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeReservedInstancesOfferingsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesOfferings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'reservedInstancesOfferingsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ReservedInstancesOfferingId' => array( 'type' => 'string', 'sentAs' => 'reservedInstancesOfferingId', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Duration' => array( 'type' => 'numeric', 'sentAs' => 'duration', ), 'UsagePrice' => array( 'type' => 'numeric', 'sentAs' => 'usagePrice', ), 'FixedPrice' => array( 'type' => 'numeric', 'sentAs' => 'fixedPrice', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'InstanceTenancy' => array( 'type' => 'string', 'sentAs' => 'instanceTenancy', ), 'CurrencyCode' => array( 'type' => 'string', 'sentAs' => 'currencyCode', ), 'OfferingType' => array( 'type' => 'string', 'sentAs' => 'offeringType', ), 'RecurringCharges' => array( 'type' => 'array', 'sentAs' => 'recurringCharges', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Frequency' => array( 'type' => 'string', 'sentAs' => 'frequency', ), 'Amount' => array( 'type' => 'numeric', 'sentAs' => 'amount', ), ), ), ), 'Marketplace' => array( 'type' => 'boolean', 'sentAs' => 'marketplace', ), 'PricingDetails' => array( 'type' => 'array', 'sentAs' => 'pricingDetailsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Price' => array( 'type' => 'numeric', 'sentAs' => 'price', ), 'Count' => array( 'type' => 'numeric', 'sentAs' => 'count', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeRouteTablesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RouteTables' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'routeTableSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RouteTableId' => array( 'type' => 'string', 'sentAs' => 'routeTableId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Routes' => array( 'type' => 'array', 'sentAs' => 'routeSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DestinationCidrBlock' => array( 'type' => 'string', 'sentAs' => 'destinationCidrBlock', ), 'GatewayId' => array( 'type' => 'string', 'sentAs' => 'gatewayId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'InstanceOwnerId' => array( 'type' => 'string', 'sentAs' => 'instanceOwnerId', ), 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Associations' => array( 'type' => 'array', 'sentAs' => 'associationSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'RouteTableAssociationId' => array( 'type' => 'string', 'sentAs' => 'routeTableAssociationId', ), 'RouteTableId' => array( 'type' => 'string', 'sentAs' => 'routeTableId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'Main' => array( 'type' => 'boolean', 'sentAs' => 'main', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'PropagatingVgws' => array( 'type' => 'array', 'sentAs' => 'propagatingVgwSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GatewayId' => array( 'type' => 'string', 'sentAs' => 'gatewayId', ), ), ), ), ), ), ), ), ), 'DescribeSecurityGroupsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'securityGroupInfo', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'groupDescription', ), 'IpPermissions' => array( 'type' => 'array', 'sentAs' => 'ipPermissions', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', 'sentAs' => 'ipProtocol', ), 'FromPort' => array( 'type' => 'numeric', 'sentAs' => 'fromPort', ), 'ToPort' => array( 'type' => 'numeric', 'sentAs' => 'toPort', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'groups', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'UserId' => array( 'type' => 'string', 'sentAs' => 'userId', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'sentAs' => 'ipRanges', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'CidrIp' => array( 'type' => 'string', 'sentAs' => 'cidrIp', ), ), ), ), ), ), ), 'IpPermissionsEgress' => array( 'type' => 'array', 'sentAs' => 'ipPermissionsEgress', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'IpProtocol' => array( 'type' => 'string', 'sentAs' => 'ipProtocol', ), 'FromPort' => array( 'type' => 'numeric', 'sentAs' => 'fromPort', ), 'ToPort' => array( 'type' => 'numeric', 'sentAs' => 'toPort', ), 'UserIdGroupPairs' => array( 'type' => 'array', 'sentAs' => 'groups', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'UserId' => array( 'type' => 'string', 'sentAs' => 'userId', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'IpRanges' => array( 'type' => 'array', 'sentAs' => 'ipRanges', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'CidrIp' => array( 'type' => 'string', 'sentAs' => 'cidrIp', ), ), ), ), ), ), ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeSnapshotAttributeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'snapshotId', ), 'CreateVolumePermissions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'createVolumePermission', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'UserId' => array( 'type' => 'string', 'sentAs' => 'userId', ), 'Group' => array( 'type' => 'string', 'sentAs' => 'group', ), ), ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), ), ), 'DescribeSnapshotsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Snapshots' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'snapshotSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StartTime' => array( 'type' => 'string', 'sentAs' => 'startTime', ), 'Progress' => array( 'type' => 'string', 'sentAs' => 'progress', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'OwnerAlias' => array( 'type' => 'string', 'sentAs' => 'ownerAlias', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeSpotDatafeedSubscriptionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotDatafeedSubscription' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'spotDatafeedSubscription', 'properties' => array( 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Bucket' => array( 'type' => 'string', 'sentAs' => 'bucket', ), 'Prefix' => array( 'type' => 'string', 'sentAs' => 'prefix', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Fault' => array( 'type' => 'object', 'sentAs' => 'fault', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), ), ), ), ), 'DescribeSpotInstanceRequestsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotInstanceRequests' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'spotInstanceRequestSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'SpotPrice' => array( 'type' => 'string', 'sentAs' => 'spotPrice', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Fault' => array( 'type' => 'object', 'sentAs' => 'fault', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'Status' => array( 'type' => 'object', 'sentAs' => 'status', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'ValidFrom' => array( 'type' => 'string', 'sentAs' => 'validFrom', ), 'ValidUntil' => array( 'type' => 'string', 'sentAs' => 'validUntil', ), 'LaunchGroup' => array( 'type' => 'string', 'sentAs' => 'launchGroup', ), 'AvailabilityZoneGroup' => array( 'type' => 'string', 'sentAs' => 'availabilityZoneGroup', ), 'LaunchSpecification' => array( 'type' => 'object', 'sentAs' => 'launchSpecification', 'properties' => array( 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'UserData' => array( 'type' => 'string', 'sentAs' => 'userData', ), 'AddressingType' => array( 'type' => 'string', 'sentAs' => 'addressingType', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'Placement' => array( 'type' => 'object', 'sentAs' => 'placement', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), ), ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'sentAs' => 'virtualName', ), 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), 'NoDevice' => array( 'type' => 'string', 'sentAs' => 'noDevice', ), ), ), ), 'MonitoringEnabled' => array( 'type' => 'boolean', 'sentAs' => 'monitoringEnabled', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', 'sentAs' => 'SecurityGroupId', ), ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', 'sentAs' => 'secondaryPrivateIpAddressCount', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'sentAs' => 'associatePublicIpAddress', ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'sentAs' => 'iamInstanceProfile', 'properties' => array( 'Arn' => array( 'type' => 'string', 'sentAs' => 'arn', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'sentAs' => 'ebsOptimized', ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CreateTime' => array( 'type' => 'string', 'sentAs' => 'createTime', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'LaunchedAvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'launchedAvailabilityZone', ), ), ), ), ), ), 'DescribeSpotPriceHistoryResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotPriceHistory' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'spotPriceHistorySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'SpotPrice' => array( 'type' => 'string', 'sentAs' => 'spotPrice', ), 'Timestamp' => array( 'type' => 'string', 'sentAs' => 'timestamp', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeSubnetsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subnets' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'subnetSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'AvailableIpAddressCount' => array( 'type' => 'numeric', 'sentAs' => 'availableIpAddressCount', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'DefaultForAz' => array( 'type' => 'boolean', 'sentAs' => 'defaultForAz', ), 'MapPublicIpOnLaunch' => array( 'type' => 'boolean', 'sentAs' => 'mapPublicIpOnLaunch', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'DescribeTagsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Tags' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ResourceId' => array( 'type' => 'string', 'sentAs' => 'resourceId', ), 'ResourceType' => array( 'type' => 'string', 'sentAs' => 'resourceType', ), 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeVolumeAttributeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'volumeId', ), 'AutoEnableIO' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'autoEnableIO', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'ProductCodes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), ), ), 'DescribeVolumeStatusResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeStatuses' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'volumeStatusSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'VolumeStatus' => array( 'type' => 'object', 'sentAs' => 'volumeStatus', 'properties' => array( 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'Details' => array( 'type' => 'array', 'sentAs' => 'details', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), ), ), ), ), ), 'Events' => array( 'type' => 'array', 'sentAs' => 'eventsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'EventType' => array( 'type' => 'string', 'sentAs' => 'eventType', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'NotBefore' => array( 'type' => 'string', 'sentAs' => 'notBefore', ), 'NotAfter' => array( 'type' => 'string', 'sentAs' => 'notAfter', ), 'EventId' => array( 'type' => 'string', 'sentAs' => 'eventId', ), ), ), ), 'Actions' => array( 'type' => 'array', 'sentAs' => 'actionsSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'EventType' => array( 'type' => 'string', 'sentAs' => 'eventType', ), 'EventId' => array( 'type' => 'string', 'sentAs' => 'eventId', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'nextToken', ), ), ), 'DescribeVolumesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Volumes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'volumeSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'State' => array( 'type' => 'string', 'sentAs' => 'status', ), 'CreateTime' => array( 'type' => 'string', 'sentAs' => 'createTime', ), 'Attachments' => array( 'type' => 'array', 'sentAs' => 'attachmentSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Device' => array( 'type' => 'string', 'sentAs' => 'device', ), 'State' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), ), ), ), 'DescribeVpcAttributeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpcId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'vpcId', ), 'EnableDnsSupport' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'enableDnsSupport', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), 'EnableDnsHostnames' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'enableDnsHostnames', 'properties' => array( 'Value' => array( 'type' => 'boolean', 'sentAs' => 'value', ), ), ), ), ), 'DescribeVpcsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Vpcs' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'vpcSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'CidrBlock' => array( 'type' => 'string', 'sentAs' => 'cidrBlock', ), 'DhcpOptionsId' => array( 'type' => 'string', 'sentAs' => 'dhcpOptionsId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'InstanceTenancy' => array( 'type' => 'string', 'sentAs' => 'instanceTenancy', ), 'IsDefault' => array( 'type' => 'boolean', 'sentAs' => 'isDefault', ), ), ), ), ), ), 'DescribeVpnConnectionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpnConnections' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'vpnConnectionSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpnConnectionId' => array( 'type' => 'string', 'sentAs' => 'vpnConnectionId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'CustomerGatewayConfiguration' => array( 'type' => 'string', 'sentAs' => 'customerGatewayConfiguration', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'CustomerGatewayId' => array( 'type' => 'string', 'sentAs' => 'customerGatewayId', ), 'VpnGatewayId' => array( 'type' => 'string', 'sentAs' => 'vpnGatewayId', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'VgwTelemetry' => array( 'type' => 'array', 'sentAs' => 'vgwTelemetry', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'OutsideIpAddress' => array( 'type' => 'string', 'sentAs' => 'outsideIpAddress', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'LastStatusChange' => array( 'type' => 'string', 'sentAs' => 'lastStatusChange', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'AcceptedRouteCount' => array( 'type' => 'numeric', 'sentAs' => 'acceptedRouteCount', ), ), ), ), 'Options' => array( 'type' => 'object', 'sentAs' => 'options', 'properties' => array( 'StaticRoutesOnly' => array( 'type' => 'boolean', 'sentAs' => 'staticRoutesOnly', ), ), ), 'Routes' => array( 'type' => 'array', 'sentAs' => 'routes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DestinationCidrBlock' => array( 'type' => 'string', 'sentAs' => 'destinationCidrBlock', ), 'Source' => array( 'type' => 'string', 'sentAs' => 'source', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), ), ), ), 'DescribeVpnGatewaysResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VpnGateways' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'vpnGatewaySet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpnGatewayId' => array( 'type' => 'string', 'sentAs' => 'vpnGatewayId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'VpcAttachments' => array( 'type' => 'array', 'sentAs' => 'attachments', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), ), 'GetConsoleOutputResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'instanceId', ), 'Timestamp' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'timestamp', ), 'Output' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'output', ), ), ), 'GetPasswordDataResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'instanceId', ), 'Timestamp' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'timestamp', ), 'PasswordData' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'passwordData', ), ), ), 'ImportInstanceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ConversionTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'conversionTask', 'properties' => array( 'ConversionTaskId' => array( 'type' => 'string', 'sentAs' => 'conversionTaskId', ), 'ExpirationTime' => array( 'type' => 'string', 'sentAs' => 'expirationTime', ), 'ImportInstance' => array( 'type' => 'object', 'sentAs' => 'importInstance', 'properties' => array( 'Volumes' => array( 'type' => 'array', 'sentAs' => 'volumes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), 'ImportVolume' => array( 'type' => 'object', 'sentAs' => 'importVolume', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), ), ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'ImportKeyPairResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'KeyName' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyName', ), 'KeyFingerprint' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'keyFingerprint', ), ), ), 'ImportVolumeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ConversionTask' => array( 'type' => 'object', 'location' => 'xml', 'sentAs' => 'conversionTask', 'properties' => array( 'ConversionTaskId' => array( 'type' => 'string', 'sentAs' => 'conversionTaskId', ), 'ExpirationTime' => array( 'type' => 'string', 'sentAs' => 'expirationTime', ), 'ImportInstance' => array( 'type' => 'object', 'sentAs' => 'importInstance', 'properties' => array( 'Volumes' => array( 'type' => 'array', 'sentAs' => 'volumes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), ), ), 'ImportVolume' => array( 'type' => 'object', 'sentAs' => 'importVolume', 'properties' => array( 'BytesConverted' => array( 'type' => 'numeric', 'sentAs' => 'bytesConverted', ), 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'Image' => array( 'type' => 'object', 'sentAs' => 'image', 'properties' => array( 'Format' => array( 'type' => 'string', 'sentAs' => 'format', ), 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'ImportManifestUrl' => array( 'type' => 'string', 'sentAs' => 'importManifestUrl', ), 'Checksum' => array( 'type' => 'string', 'sentAs' => 'checksum', ), ), ), 'Volume' => array( 'type' => 'object', 'sentAs' => 'volume', 'properties' => array( 'Size' => array( 'type' => 'numeric', 'sentAs' => 'size', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), ), ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'StatusMessage' => array( 'type' => 'string', 'sentAs' => 'statusMessage', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), ), ), ), ), 'ModifyReservedInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesModificationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'reservedInstancesModificationId', ), ), ), 'MonitorInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceMonitorings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Monitoring' => array( 'type' => 'object', 'sentAs' => 'monitoring', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), ), ), 'PurchaseReservedInstancesOfferingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedInstancesId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'reservedInstancesId', ), ), ), 'RegisterImageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ImageId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'imageId', ), ), ), 'ReplaceNetworkAclAssociationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NewAssociationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'newAssociationId', ), ), ), 'ReplaceRouteTableAssociationResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NewAssociationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'newAssociationId', ), ), ), 'RequestSpotInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SpotInstanceRequests' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'spotInstanceRequestSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'SpotPrice' => array( 'type' => 'string', 'sentAs' => 'spotPrice', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'type', ), 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), 'Fault' => array( 'type' => 'object', 'sentAs' => 'fault', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'Status' => array( 'type' => 'object', 'sentAs' => 'status', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'UpdateTime' => array( 'type' => 'string', 'sentAs' => 'updateTime', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'ValidFrom' => array( 'type' => 'string', 'sentAs' => 'validFrom', ), 'ValidUntil' => array( 'type' => 'string', 'sentAs' => 'validUntil', ), 'LaunchGroup' => array( 'type' => 'string', 'sentAs' => 'launchGroup', ), 'AvailabilityZoneGroup' => array( 'type' => 'string', 'sentAs' => 'availabilityZoneGroup', ), 'LaunchSpecification' => array( 'type' => 'object', 'sentAs' => 'launchSpecification', 'properties' => array( 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'UserData' => array( 'type' => 'string', 'sentAs' => 'userData', ), 'AddressingType' => array( 'type' => 'string', 'sentAs' => 'addressingType', ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'Placement' => array( 'type' => 'object', 'sentAs' => 'placement', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), ), ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'VirtualName' => array( 'type' => 'string', 'sentAs' => 'virtualName', ), 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'sentAs' => 'snapshotId', ), 'VolumeSize' => array( 'type' => 'numeric', 'sentAs' => 'volumeSize', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'VolumeType' => array( 'type' => 'string', 'sentAs' => 'volumeType', ), 'Iops' => array( 'type' => 'numeric', 'sentAs' => 'iops', ), ), ), 'NoDevice' => array( 'type' => 'string', 'sentAs' => 'noDevice', ), ), ), ), 'MonitoringEnabled' => array( 'type' => 'boolean', 'sentAs' => 'monitoringEnabled', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'SecurityGroupId', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', 'sentAs' => 'SecurityGroupId', ), ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), ), ), ), 'SecondaryPrivateIpAddressCount' => array( 'type' => 'numeric', 'sentAs' => 'secondaryPrivateIpAddressCount', ), 'AssociatePublicIpAddress' => array( 'type' => 'boolean', 'sentAs' => 'associatePublicIpAddress', ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'sentAs' => 'iamInstanceProfile', 'properties' => array( 'Arn' => array( 'type' => 'string', 'sentAs' => 'arn', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'sentAs' => 'ebsOptimized', ), ), ), 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CreateTime' => array( 'type' => 'string', 'sentAs' => 'createTime', ), 'ProductDescription' => array( 'type' => 'string', 'sentAs' => 'productDescription', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'LaunchedAvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'launchedAvailabilityZone', ), ), ), ), ), ), 'reservation' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservationId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'reservationId', ), 'OwnerId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'ownerId', ), 'RequesterId' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'requesterId', ), 'Groups' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Instances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'ImageId' => array( 'type' => 'string', 'sentAs' => 'imageId', ), 'State' => array( 'type' => 'object', 'sentAs' => 'instanceState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'dnsName', ), 'StateTransitionReason' => array( 'type' => 'string', 'sentAs' => 'reason', ), 'KeyName' => array( 'type' => 'string', 'sentAs' => 'keyName', ), 'AmiLaunchIndex' => array( 'type' => 'numeric', 'sentAs' => 'amiLaunchIndex', ), 'ProductCodes' => array( 'type' => 'array', 'sentAs' => 'productCodes', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'ProductCodeId' => array( 'type' => 'string', 'sentAs' => 'productCode', ), 'ProductCodeType' => array( 'type' => 'string', 'sentAs' => 'type', ), ), ), ), 'InstanceType' => array( 'type' => 'string', 'sentAs' => 'instanceType', ), 'LaunchTime' => array( 'type' => 'string', 'sentAs' => 'launchTime', ), 'Placement' => array( 'type' => 'object', 'sentAs' => 'placement', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', 'sentAs' => 'availabilityZone', ), 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'Tenancy' => array( 'type' => 'string', 'sentAs' => 'tenancy', ), ), ), 'KernelId' => array( 'type' => 'string', 'sentAs' => 'kernelId', ), 'RamdiskId' => array( 'type' => 'string', 'sentAs' => 'ramdiskId', ), 'Platform' => array( 'type' => 'string', 'sentAs' => 'platform', ), 'Monitoring' => array( 'type' => 'object', 'sentAs' => 'monitoring', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PublicIpAddress' => array( 'type' => 'string', 'sentAs' => 'ipAddress', ), 'StateReason' => array( 'type' => 'object', 'sentAs' => 'stateReason', 'properties' => array( 'Code' => array( 'type' => 'string', 'sentAs' => 'code', ), 'Message' => array( 'type' => 'string', 'sentAs' => 'message', ), ), ), 'Architecture' => array( 'type' => 'string', 'sentAs' => 'architecture', ), 'RootDeviceType' => array( 'type' => 'string', 'sentAs' => 'rootDeviceType', ), 'RootDeviceName' => array( 'type' => 'string', 'sentAs' => 'rootDeviceName', ), 'BlockDeviceMappings' => array( 'type' => 'array', 'sentAs' => 'blockDeviceMapping', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'DeviceName' => array( 'type' => 'string', 'sentAs' => 'deviceName', ), 'Ebs' => array( 'type' => 'object', 'sentAs' => 'ebs', 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'sentAs' => 'volumeId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), ), ), ), 'VirtualizationType' => array( 'type' => 'string', 'sentAs' => 'virtualizationType', ), 'InstanceLifecycle' => array( 'type' => 'string', 'sentAs' => 'instanceLifecycle', ), 'SpotInstanceRequestId' => array( 'type' => 'string', 'sentAs' => 'spotInstanceRequestId', ), 'License' => array( 'type' => 'object', 'sentAs' => 'license', 'properties' => array( 'Pool' => array( 'type' => 'string', 'sentAs' => 'pool', ), ), ), 'ClientToken' => array( 'type' => 'string', 'sentAs' => 'clientToken', ), 'Tags' => array( 'type' => 'array', 'sentAs' => 'tagSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'Key' => array( 'type' => 'string', 'sentAs' => 'key', ), 'Value' => array( 'type' => 'string', 'sentAs' => 'value', ), ), ), ), 'SecurityGroups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Hypervisor' => array( 'type' => 'string', 'sentAs' => 'hypervisor', ), 'NetworkInterfaces' => array( 'type' => 'array', 'sentAs' => 'networkInterfaceSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'NetworkInterfaceId' => array( 'type' => 'string', 'sentAs' => 'networkInterfaceId', ), 'SubnetId' => array( 'type' => 'string', 'sentAs' => 'subnetId', ), 'VpcId' => array( 'type' => 'string', 'sentAs' => 'vpcId', ), 'Description' => array( 'type' => 'string', 'sentAs' => 'description', ), 'OwnerId' => array( 'type' => 'string', 'sentAs' => 'ownerId', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'SourceDestCheck' => array( 'type' => 'boolean', 'sentAs' => 'sourceDestCheck', ), 'Groups' => array( 'type' => 'array', 'sentAs' => 'groupSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'GroupName' => array( 'type' => 'string', 'sentAs' => 'groupName', ), 'GroupId' => array( 'type' => 'string', 'sentAs' => 'groupId', ), ), ), ), 'Attachment' => array( 'type' => 'object', 'sentAs' => 'attachment', 'properties' => array( 'AttachmentId' => array( 'type' => 'string', 'sentAs' => 'attachmentId', ), 'DeviceIndex' => array( 'type' => 'numeric', 'sentAs' => 'deviceIndex', ), 'Status' => array( 'type' => 'string', 'sentAs' => 'status', ), 'AttachTime' => array( 'type' => 'string', 'sentAs' => 'attachTime', ), 'DeleteOnTermination' => array( 'type' => 'boolean', 'sentAs' => 'deleteOnTermination', ), ), ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'publicDnsName', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), ), ), 'PrivateIpAddresses' => array( 'type' => 'array', 'sentAs' => 'privateIpAddressesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'PrivateIpAddress' => array( 'type' => 'string', 'sentAs' => 'privateIpAddress', ), 'PrivateDnsName' => array( 'type' => 'string', 'sentAs' => 'privateDnsName', ), 'Primary' => array( 'type' => 'boolean', 'sentAs' => 'primary', ), 'Association' => array( 'type' => 'object', 'sentAs' => 'association', 'properties' => array( 'PublicIp' => array( 'type' => 'string', 'sentAs' => 'publicIp', ), 'PublicDnsName' => array( 'type' => 'string', 'sentAs' => 'publicDnsName', ), 'IpOwnerId' => array( 'type' => 'string', 'sentAs' => 'ipOwnerId', ), ), ), ), ), ), ), ), ), 'IamInstanceProfile' => array( 'type' => 'object', 'sentAs' => 'iamInstanceProfile', 'properties' => array( 'Arn' => array( 'type' => 'string', 'sentAs' => 'arn', ), 'Id' => array( 'type' => 'string', 'sentAs' => 'id', ), ), ), 'EbsOptimized' => array( 'type' => 'boolean', 'sentAs' => 'ebsOptimized', ), 'SriovNetSupport' => array( 'type' => 'string', 'sentAs' => 'sriovNetSupport', ), ), ), ), ), ), 'StartInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StartingInstances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CurrentState' => array( 'type' => 'object', 'sentAs' => 'currentState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PreviousState' => array( 'type' => 'object', 'sentAs' => 'previousState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), ), ), ), ), ), 'StopInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StoppingInstances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CurrentState' => array( 'type' => 'object', 'sentAs' => 'currentState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PreviousState' => array( 'type' => 'object', 'sentAs' => 'previousState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), ), ), ), ), ), 'TerminateInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TerminatingInstances' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'CurrentState' => array( 'type' => 'object', 'sentAs' => 'currentState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), 'PreviousState' => array( 'type' => 'object', 'sentAs' => 'previousState', 'properties' => array( 'Code' => array( 'type' => 'numeric', 'sentAs' => 'code', ), 'Name' => array( 'type' => 'string', 'sentAs' => 'name', ), ), ), ), ), ), ), ), 'UnmonitorInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceMonitorings' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'instancesSet', 'items' => array( 'name' => 'item', 'type' => 'object', 'sentAs' => 'item', 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'sentAs' => 'instanceId', ), 'Monitoring' => array( 'type' => 'object', 'sentAs' => 'monitoring', 'properties' => array( 'State' => array( 'type' => 'string', 'sentAs' => 'state', ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeAccountAttributes' => array( 'result_key' => 'AccountAttributes', ), 'DescribeAddresses' => array( 'result_key' => 'Addresses', ), 'DescribeAvailabilityZones' => array( 'result_key' => 'AvailabilityZones', ), 'DescribeBundleTasks' => array( 'result_key' => 'BundleTasks', ), 'DescribeConversionTasks' => array( 'result_key' => 'ConversionTasks', ), 'DescribeCustomerGateways' => array( 'result_key' => 'CustomerGateways', ), 'DescribeDhcpOptions' => array( 'result_key' => 'DhcpOptions', ), 'DescribeExportTasks' => array( 'result_key' => 'ExportTasks', ), 'DescribeImages' => array( 'result_key' => 'Images', ), 'DescribeInstanceStatus' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'InstanceStatuses', ), 'DescribeInstances' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'Reservations', ), 'DescribeInternetGateways' => array( 'result_key' => 'InternetGateways', ), 'DescribeKeyPairs' => array( 'result_key' => 'KeyPairs', ), 'DescribeLicenses' => array( 'result_key' => 'Licenses', ), 'DescribeNetworkAcls' => array( 'result_key' => 'NetworkAcls', ), 'DescribeNetworkInterfaces' => array( 'result_key' => 'NetworkInterfaces', ), 'DescribePlacementGroups' => array( 'result_key' => 'PlacementGroups', ), 'DescribeRegions' => array( 'result_key' => 'Regions', ), 'DescribeReservedInstances' => array( 'result_key' => 'ReservedInstances', ), 'DescribeReservedInstancesListings' => array( 'result_key' => 'ReservedInstancesListings', ), 'DescribeReservedInstancesModifications' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'ReservedInstancesModifications', ), 'DescribeReservedInstancesOfferings' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'ReservedInstancesOfferings', ), 'DescribeRouteTables' => array( 'result_key' => 'RouteTables', ), 'DescribeSecurityGroups' => array( 'result_key' => 'SecurityGroups', ), 'DescribeSnapshots' => array( 'result_key' => 'Snapshots', ), 'DescribeSpotInstanceRequests' => array( 'result_key' => 'SpotInstanceRequests', ), 'DescribeSpotPriceHistory' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'SpotPriceHistory', ), 'DescribeSubnets' => array( 'result_key' => 'Subnets', ), 'DescribeTags' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'Tags', ), 'DescribeVolumeStatus' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxResults', 'result_key' => 'VolumeStatuses', ), 'DescribeVolumes' => array( 'result_key' => 'Volumes', ), 'DescribeVpcs' => array( 'result_key' => 'Vpcs', ), 'DescribeVpnConnections' => array( 'result_key' => 'VpnConnections', ), 'DescribeVpnGateways' => array( 'result_key' => 'VpnGateways', ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 15, 'max_attempts' => 40, 'acceptor.type' => 'output', ), '__InstanceState' => array( 'operation' => 'DescribeInstances', 'acceptor.path' => 'Reservations/*/Instances/*/State/Name', ), 'InstanceRunning' => array( 'extends' => '__InstanceState', 'success.value' => 'running', 'failure.value' => array( 'shutting-down', 'terminated', 'stopping', ), ), 'InstanceStopped' => array( 'extends' => '__InstanceState', 'success.value' => 'stopped', 'failure.value' => array( 'pending', 'terminated', ), ), 'InstanceTerminated' => array( 'extends' => '__InstanceState', 'success.value' => 'terminated', 'failure.value' => array( 'pending', 'stopping', ), ), '__ExportTaskState' => array( 'operation' => 'DescribeExportTasks', 'acceptor.path' => 'ExportTasks/*/State', ), 'ExportTaskCompleted' => array( 'extends' => '__ExportTaskState', 'success.value' => 'completed', ), 'ExportTaskCancelled' => array( 'extends' => '__ExportTaskState', 'success.value' => 'cancelled', ), 'SnapshotCompleted' => array( 'operation' => 'DescribeSnapshots', 'success.path' => 'Snapshots/*/State', 'success.value' => 'completed', ), 'SubnetAvailable' => array( 'operation' => 'DescribeSubnets', 'success.path' => 'Subnets/*/State', 'success.value' => 'available', ), '__VolumeStatus' => array( 'operation' => 'DescribeVolumes', 'acceptor.key' => 'VolumeStatuses/*/VolumeStatus/Status', ), 'VolumeAvailable' => array( 'extends' => '__VolumeStatus', 'success.value' => 'available', 'failure.value' => array( 'deleted', ), ), 'VolumeInUse' => array( 'extends' => '__VolumeStatus', 'success.value' => 'in-use', 'failure.value' => array( 'deleted', ), ), 'VolumeDeleted' => array( 'extends' => '__VolumeStatus', 'success.value' => 'deleted', ), 'VpcAvailable' => array( 'operation' => 'DescribeVpcs', 'success.path' => 'Vpcs/*/State', 'success.value' => 'available', ), '__VpnConnectionState' => array( 'operation' => 'DescribeVpnConnections', 'acceptor.path' => 'VpnConnections/*/State', ), 'VpnConnectionAvailable' => array( 'extends' => '__VpnConnectionState', 'success.value' => 'available', 'failure.value' => array( 'deleting', 'deleted', ), ), 'VpnConnectionDeleted' => array( 'extends' => '__VpnConnectionState', 'success.value' => 'deleted', 'failure.value' => array( 'pending', ), ), 'BundleTaskComplete' => array( 'operation' => 'DescribeBundleTasks', 'acceptor.path' => 'BundleTasks/*/State', 'success.value' => 'complete', 'failure.value' => array( 'failed', ), ), '__ConversionTaskState' => array( 'operation' => 'DescribeConversionTasks', 'acceptor.path' => 'ConversionTasks/*/State', ), 'ConversionTaskCompleted' => array( 'extends' => '__ConversionTaskState', 'success.value' => 'completed', 'failure.value' => array( 'cancelled', 'cancelling', ), ), 'ConversionTaskCancelled' => array( 'extends' => '__ConversionTaskState', 'success.value' => 'cancelled', ), '__CustomerGatewayState' => array( 'operation' => 'DescribeCustomerGateways', 'acceptor.path' => 'CustomerGateways/*/State', ), 'CustomerGatewayAvailable' => array( 'extends' => '__CustomerGatewayState', 'success.value' => 'available', 'failure.value' => array( 'deleted', 'deleting', ), ), 'ConversionTaskDeleted' => array( 'extends' => '__CustomerGatewayState', 'success.value' => 'deleted', ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elasticache-%s.php' )) ->build(); } } '2013-06-15', 'endpointPrefix' => 'elasticache', 'serviceFullName' => 'Amazon ElastiCache', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'ElastiCache', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.ap-southeast-2.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.cn-north-1.amazonaws.com.cn', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticache.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'AuthorizeCacheSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeCacheSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The specified Amazon EC2 security group is already authorized for the specified cache security group.', 'class' => 'AuthorizationAlreadyExistsException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'CreateCacheCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCacheCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReplicationGroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NumCacheNodes' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'CacheNodeType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Engine' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheSecurityGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheSecurityGroupNames.member', 'items' => array( 'name' => 'CacheSecurityGroupName', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupIds.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'SnapshotArns' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SnapshotArns.member', 'items' => array( 'name' => 'SnapshotArn', 'type' => 'string', ), ), 'PreferredAvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'NotificationTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified replication group does not exist.', 'class' => 'ReplicationGroupNotFoundException', ), array( 'reason' => 'The requested replication group is not in the available state.', 'class' => 'InvalidReplicationGroupStateException', ), array( 'reason' => 'This user already has a cache cluster with the given identifier.', 'class' => 'CacheClusterAlreadyExistsException', ), array( 'reason' => 'The requested cache node type is not available in the specified Availability Zone.', 'class' => 'InsufficientCacheClusterCapacityException', ), array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The requested cache subnet group name does not refer to an existing cache subnet group.', 'class' => 'CacheSubnetGroupNotFoundException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache clusters per customer.', 'class' => 'ClusterQuotaForCustomerExceededException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes in a single cache cluster.', 'class' => 'NodeQuotaForClusterExceededException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes per customer.', 'class' => 'NodeQuotaForCustomerExceededException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The VPC network is in an invalid state.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'CreateCacheParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCacheParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request cannot be processed because it would exceed the maximum number of cache security groups.', 'class' => 'CacheParameterGroupQuotaExceededException', ), array( 'reason' => 'A cache parameter group with the requested name already exists.', 'class' => 'CacheParameterGroupAlreadyExistsException', ), array( 'reason' => 'The current state of the cache parameter group does not allow the requested action to occur.', 'class' => 'InvalidCacheParameterGroupStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'CreateCacheSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCacheSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'A cache security group with the specified name already exists.', 'class' => 'CacheSecurityGroupAlreadyExistsException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache security groups.', 'class' => 'CacheSecurityGroupQuotaExceededException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'CreateCacheSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCacheSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CacheSubnetGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache subnet group name is already in use by an existing cache subnet group.', 'class' => 'CacheSubnetGroupAlreadyExistsException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache subnet groups.', 'class' => 'CacheSubnetGroupQuotaExceededException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of subnets in a cache subnet group.', 'class' => 'CacheSubnetQuotaExceededException', ), array( 'reason' => 'An invalid subnet identifier was specified.', 'class' => 'InvalidSubnetException', ), ), ), 'CreateReplicationGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplicationGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateReplicationGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReplicationGroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PrimaryClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReplicationGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The specified replication group already exists.', 'class' => 'ReplicationGroupAlreadyExistsException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DeleteCacheCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCacheCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DeleteCacheParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCacheParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The current state of the cache parameter group does not allow the requested action to occur.', 'class' => 'InvalidCacheParameterGroupStateException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DeleteCacheSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCacheSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DeleteCacheSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCacheSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache subnet group is currently in use.', 'class' => 'CacheSubnetGroupInUseException', ), array( 'reason' => 'The requested cache subnet group name does not refer to an existing cache subnet group.', 'class' => 'CacheSubnetGroupNotFoundException', ), ), ), 'DeleteReplicationGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplicationGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteReplicationGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReplicationGroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified replication group does not exist.', 'class' => 'ReplicationGroupNotFoundException', ), array( 'reason' => 'The requested replication group is not in the available state.', 'class' => 'InvalidReplicationGroupStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheClusters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheClusters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ShowCacheNodeInfo' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheEngineVersions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheEngineVersionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheEngineVersions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'Engine' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupFamily' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DefaultOnly' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DescribeCacheParameterGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheParameterGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupDetails', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Source' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheSecurityGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSecurityGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheSecurityGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeCacheSubnetGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSubnetGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeCacheSubnetGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache subnet group name does not refer to an existing cache subnet group.', 'class' => 'CacheSubnetGroupNotFoundException', ), ), ), 'DescribeEngineDefaultParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EngineDefaultsWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEngineDefaultParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'SourceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeReplicationGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplicationGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReplicationGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReplicationGroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified replication group does not exist.', 'class' => 'ReplicationGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeReservedCacheNodes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedCacheNodeMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedCacheNodes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReservedCacheNodeId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheNodeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested reserved cache node was not found.', 'class' => 'ReservedCacheNodeNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'DescribeReservedCacheNodesOfferings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedCacheNodesOfferingMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedCacheNodesOfferings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheNodeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache node offering does not exist.', 'class' => 'ReservedCacheNodesOfferingNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'ModifyCacheCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyCacheCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NumCacheNodes' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'CacheNodeIdsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheNodeIdsToRemove.member', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', ), ), 'CacheSecurityGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheSecurityGroupNames.member', 'items' => array( 'name' => 'CacheSecurityGroupName', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupIds.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NotificationTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NotificationTopicStatus' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ApplyImmediately' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes in a single cache cluster.', 'class' => 'NodeQuotaForClusterExceededException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes per customer.', 'class' => 'NodeQuotaForCustomerExceededException', ), array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The VPC network is in an invalid state.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'ModifyCacheParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyCacheParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ParameterNameValues' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ParameterNameValues.member', 'items' => array( 'name' => 'ParameterNameValue', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The current state of the cache parameter group does not allow the requested action to occur.', 'class' => 'InvalidCacheParameterGroupStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'ModifyCacheSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyCacheSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CacheSubnetGroupDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache subnet group name does not refer to an existing cache subnet group.', 'class' => 'CacheSubnetGroupNotFoundException', ), array( 'reason' => 'The request cannot be processed because it would exceed the allowed number of subnets in a cache subnet group.', 'class' => 'CacheSubnetQuotaExceededException', ), array( 'reason' => 'The requested subnet is being used by another cache subnet group.', 'class' => 'SubnetInUseException', ), array( 'reason' => 'An invalid subnet identifier was specified.', 'class' => 'InvalidSubnetException', ), ), ), 'ModifyReplicationGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReplicationGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyReplicationGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReplicationGroupId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReplicationGroupDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheSecurityGroupNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheSecurityGroupNames.member', 'items' => array( 'name' => 'CacheSecurityGroupName', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroupIds.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NotificationTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NotificationTopicStatus' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ApplyImmediately' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PrimaryClusterId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified replication group does not exist.', 'class' => 'ReplicationGroupNotFoundException', ), array( 'reason' => 'The requested replication group is not in the available state.', 'class' => 'InvalidReplicationGroupStateException', ), array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The VPC network is in an invalid state.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'PurchaseReservedCacheNodesOffering' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedCacheNodeWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PurchaseReservedCacheNodesOffering', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'ReservedCacheNodesOfferingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReservedCacheNodeId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CacheNodeCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache node offering does not exist.', 'class' => 'ReservedCacheNodesOfferingNotFoundException', ), array( 'reason' => 'This user already has a reservation with the given identifier.', 'class' => 'ReservedCacheNodeAlreadyExistsException', ), array( 'reason' => 'The request cannot be processed because it would exceed the user\'s cache node quota.', 'class' => 'ReservedCacheNodeQuotaExceededException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'RebootCacheCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebootCacheCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheClusterId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CacheNodeIdsToReboot' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'CacheNodeIdsToReboot.member', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache cluster is not in the available state.', 'class' => 'InvalidCacheClusterStateException', ), array( 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', 'class' => 'CacheClusterNotFoundException', ), ), ), 'ResetCacheParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetCacheParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ResetAllParameters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ParameterNameValues' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ParameterNameValues.member', 'items' => array( 'name' => 'ParameterNameValue', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The current state of the cache parameter group does not allow the requested action to occur.', 'class' => 'InvalidCacheParameterGroupStateException', ), array( 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', 'class' => 'CacheParameterGroupNotFoundException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), 'RevokeCacheSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CacheSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeCacheSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-06-15', ), 'CacheSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', 'class' => 'CacheSecurityGroupNotFoundException', ), array( 'reason' => 'The specified Amazon EC2 security group is not authorized for the specified cache security group.', 'class' => 'AuthorizationNotFoundException', ), array( 'reason' => 'The current state of the cache security group does not allow deletion.', 'class' => 'InvalidCacheSecurityGroupStateException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Two or more incompatible parameters were specified.', 'class' => 'InvalidParameterCombinationException', ), ), ), ), 'models' => array( 'CacheSecurityGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheSecurityGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'OwnerId' => array( 'type' => 'string', ), 'CacheSecurityGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'CacheClusterWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheCluster' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CacheClusterId' => array( 'type' => 'string', ), 'ConfigurationEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ClientDownloadLandingPage' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'CacheClusterStatus' => array( 'type' => 'string', ), 'NumCacheNodes' => array( 'type' => 'numeric', ), 'PreferredAvailabilityZone' => array( 'type' => 'string', ), 'CacheClusterCreateTime' => array( 'type' => 'string', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'NumCacheNodes' => array( 'type' => 'numeric', ), 'CacheNodeIdsToRemove' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', 'sentAs' => 'CacheNodeId', ), ), 'EngineVersion' => array( 'type' => 'string', ), ), ), 'NotificationConfiguration' => array( 'type' => 'object', 'properties' => array( 'TopicArn' => array( 'type' => 'string', ), 'TopicStatus' => array( 'type' => 'string', ), ), ), 'CacheSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheSecurityGroup', 'type' => 'object', 'sentAs' => 'CacheSecurityGroup', 'properties' => array( 'CacheSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'CacheParameterGroup' => array( 'type' => 'object', 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), 'CacheNodeIdsToReboot' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', 'sentAs' => 'CacheNodeId', ), ), ), ), 'CacheSubnetGroupName' => array( 'type' => 'string', ), 'CacheNodes' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNode', 'type' => 'object', 'sentAs' => 'CacheNode', 'properties' => array( 'CacheNodeId' => array( 'type' => 'string', ), 'CacheNodeStatus' => array( 'type' => 'string', ), 'CacheNodeCreateTime' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ParameterGroupStatus' => array( 'type' => 'string', ), 'SourceCacheNodeId' => array( 'type' => 'string', ), ), ), ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', ), 'SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'SecurityGroupMembership', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'ReplicationGroupId' => array( 'type' => 'string', ), ), ), ), ), 'CacheParameterGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheParameterGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', ), 'CacheParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), 'CacheSubnetGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheSubnetGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CacheSubnetGroupName' => array( 'type' => 'string', ), 'CacheSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), 'ReplicationGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReplicationGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ReplicationGroupId' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'PrimaryClusterId' => array( 'type' => 'string', ), ), ), 'MemberClusters' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterId', 'type' => 'string', 'sentAs' => 'ClusterId', ), ), 'NodeGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'NodeGroup', 'type' => 'object', 'sentAs' => 'NodeGroup', 'properties' => array( 'NodeGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'PrimaryEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'NodeGroupMembers' => array( 'type' => 'array', 'items' => array( 'name' => 'NodeGroupMember', 'type' => 'object', 'sentAs' => 'NodeGroupMember', 'properties' => array( 'CacheClusterId' => array( 'type' => 'string', ), 'CacheNodeId' => array( 'type' => 'string', ), 'ReadEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'PreferredAvailabilityZone' => array( 'type' => 'string', ), 'CurrentRole' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CacheClusterMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheClusters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheCluster', 'type' => 'object', 'sentAs' => 'CacheCluster', 'properties' => array( 'CacheClusterId' => array( 'type' => 'string', ), 'ConfigurationEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ClientDownloadLandingPage' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'CacheClusterStatus' => array( 'type' => 'string', ), 'NumCacheNodes' => array( 'type' => 'numeric', ), 'PreferredAvailabilityZone' => array( 'type' => 'string', ), 'CacheClusterCreateTime' => array( 'type' => 'string', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'NumCacheNodes' => array( 'type' => 'numeric', ), 'CacheNodeIdsToRemove' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', 'sentAs' => 'CacheNodeId', ), ), 'EngineVersion' => array( 'type' => 'string', ), ), ), 'NotificationConfiguration' => array( 'type' => 'object', 'properties' => array( 'TopicArn' => array( 'type' => 'string', ), 'TopicStatus' => array( 'type' => 'string', ), ), ), 'CacheSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheSecurityGroup', 'type' => 'object', 'sentAs' => 'CacheSecurityGroup', 'properties' => array( 'CacheSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'CacheParameterGroup' => array( 'type' => 'object', 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), 'CacheNodeIdsToReboot' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeId', 'type' => 'string', 'sentAs' => 'CacheNodeId', ), ), ), ), 'CacheSubnetGroupName' => array( 'type' => 'string', ), 'CacheNodes' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNode', 'type' => 'object', 'sentAs' => 'CacheNode', 'properties' => array( 'CacheNodeId' => array( 'type' => 'string', ), 'CacheNodeStatus' => array( 'type' => 'string', ), 'CacheNodeCreateTime' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ParameterGroupStatus' => array( 'type' => 'string', ), 'SourceCacheNodeId' => array( 'type' => 'string', ), ), ), ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', ), 'SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'SecurityGroupMembership', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'ReplicationGroupId' => array( 'type' => 'string', ), ), ), ), ), ), 'CacheEngineVersionMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheEngineVersions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheEngineVersion', 'type' => 'object', 'sentAs' => 'CacheEngineVersion', 'properties' => array( 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'CacheParameterGroupFamily' => array( 'type' => 'string', ), 'CacheEngineDescription' => array( 'type' => 'string', ), 'CacheEngineVersionDescription' => array( 'type' => 'string', ), ), ), ), ), ), 'CacheParameterGroupsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheParameterGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheParameterGroup', 'type' => 'object', 'sentAs' => 'CacheParameterGroup', 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', ), 'CacheParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'CacheParameterGroupDetails' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Parameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), 'CacheNodeTypeSpecificParameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheNodeTypeSpecificParameter', 'type' => 'object', 'sentAs' => 'CacheNodeTypeSpecificParameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'CacheNodeTypeSpecificValues' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeTypeSpecificValue', 'type' => 'object', 'sentAs' => 'CacheNodeTypeSpecificValue', 'properties' => array( 'CacheNodeType' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CacheSecurityGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheSecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheSecurityGroup', 'type' => 'object', 'sentAs' => 'CacheSecurityGroup', 'properties' => array( 'OwnerId' => array( 'type' => 'string', ), 'CacheSecurityGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CacheSubnetGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'CacheSubnetGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'CacheSubnetGroup', 'type' => 'object', 'sentAs' => 'CacheSubnetGroup', 'properties' => array( 'CacheSubnetGroupName' => array( 'type' => 'string', ), 'CacheSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'EngineDefaultsWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EngineDefaults' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CacheParameterGroupFamily' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), 'Parameters' => array( 'type' => 'array', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), 'CacheNodeTypeSpecificParameters' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeTypeSpecificParameter', 'type' => 'object', 'sentAs' => 'CacheNodeTypeSpecificParameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'CacheNodeTypeSpecificValues' => array( 'type' => 'array', 'items' => array( 'name' => 'CacheNodeTypeSpecificValue', 'type' => 'object', 'sentAs' => 'CacheNodeTypeSpecificValue', 'properties' => array( 'CacheNodeType' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'EventsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Events' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Event', 'type' => 'object', 'sentAs' => 'Event', 'properties' => array( 'SourceIdentifier' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'Date' => array( 'type' => 'string', ), ), ), ), ), ), 'ReplicationGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReplicationGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReplicationGroup', 'type' => 'object', 'sentAs' => 'ReplicationGroup', 'properties' => array( 'ReplicationGroupId' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'PrimaryClusterId' => array( 'type' => 'string', ), ), ), 'MemberClusters' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterId', 'type' => 'string', 'sentAs' => 'ClusterId', ), ), 'NodeGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'NodeGroup', 'type' => 'object', 'sentAs' => 'NodeGroup', 'properties' => array( 'NodeGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'PrimaryEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'NodeGroupMembers' => array( 'type' => 'array', 'items' => array( 'name' => 'NodeGroupMember', 'type' => 'object', 'sentAs' => 'NodeGroupMember', 'properties' => array( 'CacheClusterId' => array( 'type' => 'string', ), 'CacheNodeId' => array( 'type' => 'string', ), 'ReadEndpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'PreferredAvailabilityZone' => array( 'type' => 'string', ), 'CurrentRole' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), ), 'ReservedCacheNodeMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedCacheNodes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedCacheNode', 'type' => 'object', 'sentAs' => 'ReservedCacheNode', 'properties' => array( 'ReservedCacheNodeId' => array( 'type' => 'string', ), 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CacheNodeCount' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'State' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ReservedCacheNodesOfferingMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedCacheNodesOfferings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedCacheNodesOffering', 'type' => 'object', 'sentAs' => 'ReservedCacheNodesOffering', 'properties' => array( 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'CacheParameterGroupNameMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CacheParameterGroupName' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedCacheNodeWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedCacheNode' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ReservedCacheNodeId' => array( 'type' => 'string', ), 'ReservedCacheNodesOfferingId' => array( 'type' => 'string', ), 'CacheNodeType' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CacheNodeCount' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'State' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeCacheClusters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheClusters', ), 'DescribeCacheEngineVersions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheEngineVersions', ), 'DescribeCacheParameterGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheParameterGroups', ), 'DescribeCacheParameters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Parameters', ), 'DescribeCacheSecurityGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheSecurityGroups', ), 'DescribeCacheSubnetGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'CacheSubnetGroups', ), 'DescribeEngineDefaultParameters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Parameters', ), 'DescribeEvents' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Events', ), 'DescribeReplicationGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReplicationGroups', ), 'DescribeReservedCacheNodes' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedCacheNodes', ), 'DescribeReservedCacheNodesOfferings' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedCacheNodesOfferings', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elasticbeanstalk-%s.php' )) ->build(); } } '2010-12-01', 'endpointPrefix' => 'elasticbeanstalk', 'serviceFullName' => 'AWS Elastic Beanstalk', 'serviceAbbreviation' => 'Elastic Beanstalk', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'ElasticBeanstalk', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elasticbeanstalk.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'CheckDNSAvailability' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CheckDNSAvailabilityResultMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CheckDNSAvailability', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'CNAMEPrefix' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 63, ), ), ), 'CreateApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationDescriptionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), ), 'errorResponses' => array( array( 'reason' => 'The caller has exceeded the limit on the number of applications associated with their account.', 'class' => 'TooManyApplicationsException', ), ), ), 'CreateApplicationVersion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationVersionDescriptionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateApplicationVersion', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'SourceBundle' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'S3Bucket' => array( 'type' => 'string', 'maxLength' => 255, ), 'S3Key' => array( 'type' => 'string', 'maxLength' => 1024, ), ), ), 'AutoCreateApplication' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The caller has exceeded the limit on the number of applications associated with their account.', 'class' => 'TooManyApplicationsException', ), array( 'reason' => 'The caller has exceeded the limit on the number of application versions associated with their account.', 'class' => 'TooManyApplicationVersionsException', ), array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), array( 'reason' => 'The specified S3 bucket does not belong to the S3 region in which the service is running.', 'class' => 'S3LocationNotInServiceRegionException', ), ), ), 'CreateConfigurationTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationSettingsDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateConfigurationTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'SolutionStackName' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 100, ), 'SourceConfiguration' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 100, ), ), ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), array( 'reason' => 'The caller has exceeded the limit on the number of configuration templates associated with their account.', 'class' => 'TooManyConfigurationTemplatesException', ), ), ), 'CreateEnvironment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateEnvironment', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'CNAMEPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 63, ), 'Tier' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'SolutionStackName' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 100, ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'OptionsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToRemove.member', 'items' => array( 'name' => 'OptionSpecification', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The caller has exceeded the limit of allowed environments associated with the account.', 'class' => 'TooManyEnvironmentsException', ), array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'CreateStorageLocation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateStorageLocationResultMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateStorageLocation', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), 'errorResponses' => array( array( 'reason' => 'The web service attempted to create a bucket in an Amazon S3 account that already has 100 buckets.', 'class' => 'TooManyBucketsException', ), array( 'reason' => 'The caller does not have a subscription to Amazon S3.', 'class' => 'S3SubscriptionRequiredException', ), array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'DeleteApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TerminateEnvByForce' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because another operation is already in progress affecting an an element in this activity.', 'class' => 'OperationInProgressException', ), ), ), 'DeleteApplicationVersion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteApplicationVersion', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'DeleteSourceBundle' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Unable to delete the Amazon S3 source bundle associated with the application version, although the application version deleted successfully.', 'class' => 'SourceBundleDeletionException', ), array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), array( 'reason' => 'Unable to perform the specified operation because another operation is already in progress affecting an an element in this activity.', 'class' => 'OperationInProgressException', ), array( 'reason' => 'The specified S3 bucket does not belong to the S3 region in which the service is running.', 'class' => 'S3LocationNotInServiceRegionException', ), ), ), 'DeleteConfigurationTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteConfigurationTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because another operation is already in progress affecting an an element in this activity.', 'class' => 'OperationInProgressException', ), ), ), 'DeleteEnvironmentConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteEnvironmentConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), ), 'DescribeApplicationVersions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationVersionDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeApplicationVersions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabels' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VersionLabels.member', 'items' => array( 'name' => 'VersionLabel', 'type' => 'string', 'minLength' => 1, 'maxLength' => 100, ), ), ), ), 'DescribeApplications' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeApplications', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ApplicationNames.member', 'items' => array( 'name' => 'ApplicationName', 'type' => 'string', 'minLength' => 1, 'maxLength' => 100, ), ), ), ), 'DescribeConfigurationOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationOptionsDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeConfigurationOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'SolutionStackName' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 100, ), 'Options' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Options.member', 'items' => array( 'name' => 'OptionSpecification', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeConfigurationSettings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationSettingsDescriptions', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeConfigurationSettings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), ), 'DescribeEnvironmentResources' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentResourceDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEnvironmentResources', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'DescribeEnvironments' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEnvironments', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EnvironmentIds.member', 'items' => array( 'name' => 'EnvironmentId', 'type' => 'string', ), ), 'EnvironmentNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EnvironmentNames.member', 'items' => array( 'name' => 'EnvironmentName', 'type' => 'string', 'minLength' => 4, 'maxLength' => 23, ), ), 'IncludeDeleted' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'IncludedDeletedBackTo' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), ), ), 'DescribeEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventDescriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'RequestId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Severity' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ListAvailableSolutionStacks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListAvailableSolutionStacksResultMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListAvailableSolutionStacks', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), ), 'RebuildEnvironment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebuildEnvironment', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'RequestEnvironmentInfo' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RequestEnvironmentInfo', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'InfoType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'RestartAppServer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RestartAppServer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), ), 'RetrieveEnvironmentInfo' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RetrieveEnvironmentInfoResultMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RetrieveEnvironmentInfo', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'InfoType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'SwapEnvironmentCNAMEs' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SwapEnvironmentCNAMEs', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'SourceEnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceEnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'DestinationEnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DestinationEnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), ), ), 'TerminateEnvironment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'TerminateEnvironment', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'TerminateResources' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'UpdateApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationDescriptionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), ), ), 'UpdateApplicationVersion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplicationVersionDescriptionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateApplicationVersion', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'VersionLabel' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), ), ), 'UpdateConfigurationTemplate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationSettingsDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateConfigurationTemplate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'OptionsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToRemove.member', 'items' => array( 'name' => 'OptionSpecification', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'UpdateEnvironment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EnvironmentDescription', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateEnvironment', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', 'maxLength' => 200, ), 'Tier' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'OptionsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToRemove.member', 'items' => array( 'name' => 'OptionSpecification', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), 'ValidateConfigurationSettings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigurationSettingsValidationMessages', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ValidateConfigurationSettings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'ApplicationName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'TemplateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 100, ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 23, ), 'OptionSettings' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', 'class' => 'InsufficientPrivilegesException', ), ), ), ), 'models' => array( 'CheckDNSAvailabilityResultMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Available' => array( 'type' => 'boolean', 'location' => 'xml', ), 'FullyQualifiedCNAME' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ApplicationDescriptionMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Application' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), 'Versions' => array( 'type' => 'array', 'items' => array( 'name' => 'VersionLabel', 'type' => 'string', 'sentAs' => 'member', ), ), 'ConfigurationTemplates' => array( 'type' => 'array', 'items' => array( 'name' => 'ConfigurationTemplateName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), ), 'ApplicationVersionDescriptionMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ApplicationVersion' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'VersionLabel' => array( 'type' => 'string', ), 'SourceBundle' => array( 'type' => 'object', 'properties' => array( 'S3Bucket' => array( 'type' => 'string', ), 'S3Key' => array( 'type' => 'string', ), ), ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), ), ), ), ), 'ConfigurationSettingsDescription' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SolutionStackName' => array( 'type' => 'string', 'location' => 'xml', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'xml', ), 'TemplateName' => array( 'type' => 'string', 'location' => 'xml', ), 'Description' => array( 'type' => 'string', 'location' => 'xml', ), 'EnvironmentName' => array( 'type' => 'string', 'location' => 'xml', ), 'DeploymentStatus' => array( 'type' => 'string', 'location' => 'xml', ), 'DateCreated' => array( 'type' => 'string', 'location' => 'xml', ), 'DateUpdated' => array( 'type' => 'string', 'location' => 'xml', ), 'OptionSettings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), 'EnvironmentDescription' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EnvironmentName' => array( 'type' => 'string', 'location' => 'xml', ), 'EnvironmentId' => array( 'type' => 'string', 'location' => 'xml', ), 'ApplicationName' => array( 'type' => 'string', 'location' => 'xml', ), 'VersionLabel' => array( 'type' => 'string', 'location' => 'xml', ), 'SolutionStackName' => array( 'type' => 'string', 'location' => 'xml', ), 'TemplateName' => array( 'type' => 'string', 'location' => 'xml', ), 'Description' => array( 'type' => 'string', 'location' => 'xml', ), 'EndpointURL' => array( 'type' => 'string', 'location' => 'xml', ), 'CNAME' => array( 'type' => 'string', 'location' => 'xml', ), 'DateCreated' => array( 'type' => 'string', 'location' => 'xml', ), 'DateUpdated' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'Health' => array( 'type' => 'string', 'location' => 'xml', ), 'Resources' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'LoadBalancer' => array( 'type' => 'object', 'properties' => array( 'LoadBalancerName' => array( 'type' => 'string', ), 'Domain' => array( 'type' => 'string', ), 'Listeners' => array( 'type' => 'array', 'items' => array( 'name' => 'Listener', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Protocol' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'Tier' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), ), ), 'CreateStorageLocationResultMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'S3Bucket' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ApplicationVersionDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ApplicationVersions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ApplicationVersionDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'VersionLabel' => array( 'type' => 'string', ), 'SourceBundle' => array( 'type' => 'object', 'properties' => array( 'S3Bucket' => array( 'type' => 'string', ), 'S3Key' => array( 'type' => 'string', ), ), ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), ), ), ), ), ), 'ApplicationDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Applications' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ApplicationDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'ApplicationName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), 'Versions' => array( 'type' => 'array', 'items' => array( 'name' => 'VersionLabel', 'type' => 'string', 'sentAs' => 'member', ), ), 'ConfigurationTemplates' => array( 'type' => 'array', 'items' => array( 'name' => 'ConfigurationTemplateName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), ), ), 'ConfigurationOptionsDescription' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SolutionStackName' => array( 'type' => 'string', 'location' => 'xml', ), 'Options' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ConfigurationOptionDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'ChangeSeverity' => array( 'type' => 'string', ), 'UserDefined' => array( 'type' => 'boolean', ), 'ValueType' => array( 'type' => 'string', ), 'ValueOptions' => array( 'type' => 'array', 'items' => array( 'name' => 'ConfigurationOptionPossibleValue', 'type' => 'string', 'sentAs' => 'member', ), ), 'MinValue' => array( 'type' => 'numeric', ), 'MaxValue' => array( 'type' => 'numeric', ), 'MaxLength' => array( 'type' => 'numeric', ), 'Regex' => array( 'type' => 'object', 'properties' => array( 'Pattern' => array( 'type' => 'string', ), 'Label' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'ConfigurationSettingsDescriptions' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ConfigurationSettings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ConfigurationSettingsDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SolutionStackName' => array( 'type' => 'string', ), 'ApplicationName' => array( 'type' => 'string', ), 'TemplateName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EnvironmentName' => array( 'type' => 'string', ), 'DeploymentStatus' => array( 'type' => 'string', ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), 'OptionSettings' => array( 'type' => 'array', 'items' => array( 'name' => 'ConfigurationOptionSetting', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'EnvironmentResourceDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EnvironmentResources' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'EnvironmentName' => array( 'type' => 'string', ), 'AutoScalingGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'AutoScalingGroup', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), 'Instances' => array( 'type' => 'array', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Id' => array( 'type' => 'string', ), ), ), ), 'LaunchConfigurations' => array( 'type' => 'array', 'items' => array( 'name' => 'LaunchConfiguration', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), 'LoadBalancers' => array( 'type' => 'array', 'items' => array( 'name' => 'LoadBalancer', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), 'Triggers' => array( 'type' => 'array', 'items' => array( 'name' => 'Trigger', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), 'Queues' => array( 'type' => 'array', 'items' => array( 'name' => 'Queue', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'URL' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EnvironmentDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Environments' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EnvironmentDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'EnvironmentName' => array( 'type' => 'string', ), 'EnvironmentId' => array( 'type' => 'string', ), 'ApplicationName' => array( 'type' => 'string', ), 'VersionLabel' => array( 'type' => 'string', ), 'SolutionStackName' => array( 'type' => 'string', ), 'TemplateName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EndpointURL' => array( 'type' => 'string', ), 'CNAME' => array( 'type' => 'string', ), 'DateCreated' => array( 'type' => 'string', ), 'DateUpdated' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Health' => array( 'type' => 'string', ), 'Resources' => array( 'type' => 'object', 'properties' => array( 'LoadBalancer' => array( 'type' => 'object', 'properties' => array( 'LoadBalancerName' => array( 'type' => 'string', ), 'Domain' => array( 'type' => 'string', ), 'Listeners' => array( 'type' => 'array', 'items' => array( 'name' => 'Listener', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Protocol' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'Tier' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EventDescriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Events' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'EventDate' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'ApplicationName' => array( 'type' => 'string', ), 'VersionLabel' => array( 'type' => 'string', ), 'TemplateName' => array( 'type' => 'string', ), 'EnvironmentName' => array( 'type' => 'string', ), 'RequestId' => array( 'type' => 'string', ), 'Severity' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListAvailableSolutionStacksResultMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SolutionStacks' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SolutionStackName', 'type' => 'string', 'sentAs' => 'member', ), ), 'SolutionStackDetails' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SolutionStackDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SolutionStackName' => array( 'type' => 'string', ), 'PermittedFileTypes' => array( 'type' => 'array', 'items' => array( 'name' => 'FileTypeExtension', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), ), ), 'RetrieveEnvironmentInfoResultMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EnvironmentInfo' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EnvironmentInfoDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InfoType' => array( 'type' => 'string', ), 'Ec2InstanceId' => array( 'type' => 'string', ), 'SampleTimestamp' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), 'ConfigurationSettingsValidationMessages' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Messages' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ValidationMessage', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Message' => array( 'type' => 'string', ), 'Severity' => array( 'type' => 'string', ), 'Namespace' => array( 'type' => 'string', ), 'OptionName' => array( 'type' => 'string', ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeApplicationVersions' => array( 'result_key' => 'ApplicationVersions', ), 'DescribeApplications' => array( 'result_key' => 'Applications', ), 'DescribeConfigurationOptions' => array( 'result_key' => 'Options', ), 'DescribeEnvironments' => array( 'result_key' => 'Environments', ), 'DescribeEvents' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxRecords', 'result_key' => 'Events', ), 'ListAvailableSolutionStacks' => array( 'result_key' => 'SolutionStacks', ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 20, 'max_attempts' => 40, 'acceptor.type' => 'output', ), '__EnvironmentState' => array( 'operation' => 'DescribeEnvironments', 'acceptor.path' => 'Environments/*/Status', ), 'EnvironmentReady' => array( 'extends' => '__EnvironmentState', 'success.value' => 'Ready', 'failure.value' => array( 'Terminated', 'Terminating', ), ), 'EnvironmentTerminated' => array( 'extends' => '__EnvironmentState', 'success.value' => 'Terminated', 'failure.value' => array( 'Launching', 'Updating', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elasticloadbalancing-%s.php' )) ->build(); } } '2012-06-01', 'endpointPrefix' => 'elasticloadbalancing', 'serviceFullName' => 'Elastic Load Balancing', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'ElasticLoadBalancing', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticloadbalancing.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'ApplySecurityGroupsToLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ApplySecurityGroupsToLoadBalancerOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ApplySecurityGroupsToLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SecurityGroups' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroups.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), array( 'reason' => 'One or more specified security groups do not exist.', 'class' => 'InvalidSecurityGroupException', ), ), ), 'AttachLoadBalancerToSubnets' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AttachLoadBalancerToSubnetsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AttachLoadBalancerToSubnets', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Subnets' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Subnets.member', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), array( 'reason' => 'One or more subnets were not found.', 'class' => 'SubnetNotFoundException', ), array( 'reason' => 'The VPC has no Internet gateway.', 'class' => 'InvalidSubnetException', ), ), ), 'ConfigureHealthCheck' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfigureHealthCheckOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ConfigureHealthCheck', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HealthCheck' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Target' => array( 'required' => true, 'type' => 'string', ), 'Interval' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, 'maximum' => 300, ), 'Timeout' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, 'maximum' => 300, ), 'UnhealthyThreshold' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 2, 'maximum' => 10, ), 'HealthyThreshold' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 2, 'maximum' => 10, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), ), ), 'CreateAppCookieStickinessPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateAppCookieStickinessPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CookieName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Policy with the same name exists for this load balancer. Please choose another name.', 'class' => 'DuplicatePolicyNameException', ), array( 'reason' => 'Quota for number of policies for this load balancer has already been reached.', 'class' => 'TooManyPoliciesException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'CreateLBCookieStickinessPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLBCookieStickinessPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CookieExpirationPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Policy with the same name exists for this load balancer. Please choose another name.', 'class' => 'DuplicatePolicyNameException', ), array( 'reason' => 'Quota for number of policies for this load balancer has already been reached.', 'class' => 'TooManyPoliciesException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'CreateLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateAccessPointOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Listeners' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Listeners.member', 'items' => array( 'name' => 'Listener', 'type' => 'object', 'properties' => array( 'Protocol' => array( 'required' => true, 'type' => 'string', ), 'LoadBalancerPort' => array( 'required' => true, 'type' => 'numeric', ), 'InstanceProtocol' => array( 'type' => 'string', ), 'InstancePort' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, 'maximum' => 65535, ), 'SSLCertificateId' => array( 'type' => 'string', ), ), ), ), 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', ), ), 'Subnets' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Subnets.member', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', ), ), 'SecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SecurityGroups.member', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', ), ), 'Scheme' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Load balancer name already exists for this account. Please choose another name.', 'class' => 'DuplicateAccessPointNameException', ), array( 'reason' => 'The quota for the number of load balancers has already been reached.', 'class' => 'TooManyAccessPointsException', ), array( 'reason' => 'The specified SSL ID does not refer to a valid SSL certificate in the AWS Identity and Access Management Service.', 'class' => 'CertificateNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), array( 'reason' => 'One or more subnets were not found.', 'class' => 'SubnetNotFoundException', ), array( 'reason' => 'The VPC has no Internet gateway.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'One or more specified security groups do not exist.', 'class' => 'InvalidSecurityGroupException', ), array( 'reason' => 'Invalid value for scheme. Scheme can only be specified for load balancers in VPC.', 'class' => 'InvalidSchemeException', ), ), ), 'CreateLoadBalancerListeners' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLoadBalancerListeners', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Listeners' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Listeners.member', 'items' => array( 'name' => 'Listener', 'type' => 'object', 'properties' => array( 'Protocol' => array( 'required' => true, 'type' => 'string', ), 'LoadBalancerPort' => array( 'required' => true, 'type' => 'numeric', ), 'InstanceProtocol' => array( 'type' => 'string', ), 'InstancePort' => array( 'required' => true, 'type' => 'numeric', 'minimum' => 1, 'maximum' => 65535, ), 'SSLCertificateId' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'A Listener already exists for the given LoadBalancerName and LoadBalancerPort, but with a different InstancePort, Protocol, or SSLCertificateId.', 'class' => 'DuplicateListenerException', ), array( 'reason' => 'The specified SSL ID does not refer to a valid SSL certificate in the AWS Identity and Access Management Service.', 'class' => 'CertificateNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'CreateLoadBalancerPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLoadBalancerPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyTypeName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyAttributes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyAttributes.member', 'items' => array( 'name' => 'PolicyAttribute', 'type' => 'object', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeValue' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'One or more of the specified policy types do not exist.', 'class' => 'PolicyTypeNotFoundException', ), array( 'reason' => 'Policy with the same name exists for this load balancer. Please choose another name.', 'class' => 'DuplicatePolicyNameException', ), array( 'reason' => 'Quota for number of policies for this load balancer has already been reached.', 'class' => 'TooManyPoliciesException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'DeleteLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteLoadBalancerListeners' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLoadBalancerListeners', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LoadBalancerPorts' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LoadBalancerPorts.member', 'items' => array( 'name' => 'AccessPointPort', 'type' => 'numeric', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), ), ), 'DeleteLoadBalancerPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLoadBalancerPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'DeregisterInstancesFromLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeregisterEndPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeregisterInstancesFromLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Instances' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Instances.member', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified EndPoint is not valid.', 'class' => 'InvalidEndPointException', ), ), ), 'DescribeInstanceHealth' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeEndPointStateOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeInstanceHealth', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Instances' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Instances.member', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified EndPoint is not valid.', 'class' => 'InvalidEndPointException', ), ), ), 'DescribeLoadBalancerAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeLoadBalancerAttributesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoadBalancerAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified load balancer attribute could not be found.', 'class' => 'LoadBalancerAttributeNotFoundException', ), ), ), 'DescribeLoadBalancerPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeLoadBalancerPoliciesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoadBalancerPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PolicyNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyNames.member', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'One or more specified policies were not found.', 'class' => 'PolicyNotFoundException', ), ), ), 'DescribeLoadBalancerPolicyTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeLoadBalancerPolicyTypesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoadBalancerPolicyTypes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'PolicyTypeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyTypeNames.member', 'items' => array( 'name' => 'PolicyTypeName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more of the specified policy types do not exist.', 'class' => 'PolicyTypeNotFoundException', ), ), ), 'DescribeLoadBalancers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeAccessPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoadBalancers', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'LoadBalancerNames.member', 'items' => array( 'name' => 'AccessPointName', 'type' => 'string', ), ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), ), ), 'DetachLoadBalancerFromSubnets' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DetachLoadBalancerFromSubnetsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DetachLoadBalancerFromSubnets', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Subnets' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Subnets.member', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'DisableAvailabilityZonesForLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RemoveAvailabilityZonesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableAvailabilityZonesForLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZones' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'EnableAvailabilityZonesForLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AddAvailabilityZonesOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableAvailabilityZonesForLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZones' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AvailabilityZones.member', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), ), ), 'ModifyLoadBalancerAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyLoadBalancerAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LoadBalancerAttributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'CrossZoneLoadBalancing' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified load balancer attribute could not be found.', 'class' => 'LoadBalancerAttributeNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'RegisterInstancesWithLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'RegisterEndPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RegisterInstancesWithLoadBalancer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Instances' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Instances.member', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'The specified EndPoint is not valid.', 'class' => 'InvalidEndPointException', ), ), ), 'SetLoadBalancerListenerSSLCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetLoadBalancerListenerSSLCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LoadBalancerPort' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'SSLCertificateId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified SSL ID does not refer to a valid SSL certificate in the AWS Identity and Access Management Service.', 'class' => 'CertificateNotFoundException', ), array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'Load balancer does not have a listener configured at the given port.', 'class' => 'ListenerNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'SetLoadBalancerPoliciesForBackendServer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetLoadBalancerPoliciesForBackendServer', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'InstancePort' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'PolicyNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyNames.member', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'One or more specified policies were not found.', 'class' => 'PolicyNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), 'SetLoadBalancerPoliciesOfListener' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetLoadBalancerPoliciesOfListener', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-06-01', ), 'LoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LoadBalancerPort' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'PolicyNames' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'PolicyNames.member', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The specified load balancer could not be found.', 'class' => 'AccessPointNotFoundException', ), array( 'reason' => 'One or more specified policies were not found.', 'class' => 'PolicyNotFoundException', ), array( 'reason' => 'Load balancer does not have a listener configured at the given port.', 'class' => 'ListenerNotFoundException', ), array( 'reason' => 'Requested configuration change is invalid.', 'class' => 'InvalidConfigurationRequestException', ), ), ), ), 'models' => array( 'ApplySecurityGroupsToLoadBalancerOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'AttachLoadBalancerToSubnetsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subnets' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'ConfigureHealthCheckOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HealthCheck' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Target' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'numeric', ), 'Timeout' => array( 'type' => 'numeric', ), 'UnhealthyThreshold' => array( 'type' => 'numeric', ), 'HealthyThreshold' => array( 'type' => 'numeric', ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreateAccessPointOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DNSName' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DeregisterEndPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Instances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeEndPointStateOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceStates' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InstanceState', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'State' => array( 'type' => 'string', ), 'ReasonCode' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeLoadBalancerAttributesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoadBalancerAttributes' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'CrossZoneLoadBalancing' => array( 'type' => 'object', 'properties' => array( 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'DescribeLoadBalancerPoliciesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyDescriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'PolicyDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PolicyName' => array( 'type' => 'string', ), 'PolicyTypeName' => array( 'type' => 'string', ), 'PolicyAttributeDescriptions' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyAttributeDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeValue' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeLoadBalancerPolicyTypesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyTypeDescriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'PolicyTypeDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PolicyTypeName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'PolicyAttributeTypeDescriptions' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyAttributeTypeDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'AttributeName' => array( 'type' => 'string', ), 'AttributeType' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Cardinality' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeAccessPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoadBalancerDescriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'LoadBalancerDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'LoadBalancerName' => array( 'type' => 'string', ), 'DNSName' => array( 'type' => 'string', ), 'CanonicalHostedZoneName' => array( 'type' => 'string', ), 'CanonicalHostedZoneNameID' => array( 'type' => 'string', ), 'ListenerDescriptions' => array( 'type' => 'array', 'items' => array( 'name' => 'ListenerDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Listener' => array( 'type' => 'object', 'properties' => array( 'Protocol' => array( 'type' => 'string', ), 'LoadBalancerPort' => array( 'type' => 'numeric', ), 'InstanceProtocol' => array( 'type' => 'string', ), 'InstancePort' => array( 'type' => 'numeric', ), 'SSLCertificateId' => array( 'type' => 'string', ), ), ), 'PolicyNames' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), 'Policies' => array( 'type' => 'object', 'properties' => array( 'AppCookieStickinessPolicies' => array( 'type' => 'array', 'items' => array( 'name' => 'AppCookieStickinessPolicy', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PolicyName' => array( 'type' => 'string', ), 'CookieName' => array( 'type' => 'string', ), ), ), ), 'LBCookieStickinessPolicies' => array( 'type' => 'array', 'items' => array( 'name' => 'LBCookieStickinessPolicy', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PolicyName' => array( 'type' => 'string', ), 'CookieExpirationPeriod' => array( 'type' => 'numeric', ), ), ), ), 'OtherPolicies' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'BackendServerDescriptions' => array( 'type' => 'array', 'items' => array( 'name' => 'BackendServerDescription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstancePort' => array( 'type' => 'numeric', ), 'PolicyNames' => array( 'type' => 'array', 'items' => array( 'name' => 'PolicyName', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', 'sentAs' => 'member', ), ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', 'sentAs' => 'member', ), ), 'VPCId' => array( 'type' => 'string', ), 'Instances' => array( 'type' => 'array', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), 'HealthCheck' => array( 'type' => 'object', 'properties' => array( 'Target' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'numeric', ), 'Timeout' => array( 'type' => 'numeric', ), 'UnhealthyThreshold' => array( 'type' => 'numeric', ), 'HealthyThreshold' => array( 'type' => 'numeric', ), ), ), 'SourceSecurityGroup' => array( 'type' => 'object', 'properties' => array( 'OwnerAlias' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), ), ), 'SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'SecurityGroupId', 'type' => 'string', 'sentAs' => 'member', ), ), 'CreatedTime' => array( 'type' => 'string', ), 'Scheme' => array( 'type' => 'string', ), ), ), ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DetachLoadBalancerFromSubnetsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subnets' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SubnetId', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'RemoveAvailabilityZonesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'AddAvailabilityZonesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AvailabilityZones' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'RegisterEndPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Instances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeInstanceHealth' => array( 'result_key' => 'InstanceStates', ), 'DescribeLoadBalancerPolicies' => array( 'result_key' => 'PolicyDescriptions', ), 'DescribeLoadBalancerPolicyTypes' => array( 'result_key' => 'PolicyTypeDescriptions', ), 'DescribeLoadBalancers' => array( 'token_param' => 'Marker', 'token_key' => 'NextMarker', 'result_key' => 'LoadBalancerDescriptions', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elastictranscoder-%s.php' )) ->setExceptionParser(new JsonRestExceptionParser()) ->build(); } } '2012-09-25', 'endpointPrefix' => 'elastictranscoder', 'serviceFullName' => 'Amazon Elastic Transcoder', 'serviceType' => 'rest-json', 'signatureVersion' => 'v4', 'namespace' => 'ElasticTranscoder', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'elastictranscoder.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'CancelJob' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-09-25/jobs/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'CreateJob' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/jobs', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateJobResponse', 'responseType' => 'model', 'parameters' => array( 'PipelineId' => array( 'type' => 'string', 'location' => 'json', ), 'Input' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Key' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Key' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 40, ), 'InputKey' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 30, 'items' => array( 'name' => 'CreateJobOutput', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 40, ), 'InputKey' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), 'Playlists' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 30, 'items' => array( 'name' => 'CreateJobPlaylist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Key', 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Too many operations for a given AWS account. For example, the number of pipelines exceeds the maximum allowed.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'CreatePipeline' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/pipelines', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreatePipelineResponse', 'responseType' => 'model', 'parameters' => array( 'Name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 40, ), 'InputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'OutputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'Role' => array( 'type' => 'string', 'location' => 'json', ), 'Notifications' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Access' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Access' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Too many operations for a given AWS account. For example, the number of pipelines exceeds the maximum allowed.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'CreatePreset' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/presets', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreatePresetResponse', 'responseType' => 'model', 'parameters' => array( 'Name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 40, ), 'Description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 255, ), 'Container' => array( 'type' => 'string', 'location' => 'json', ), 'Video' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, 'data' => array( 'shape_name' => 'CodecOption', ), ), ), 'KeyframesMaxDist' => array( 'type' => 'string', ), 'FixedGOP' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'MaxFrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'DisplayAspectRatio' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'PresetWatermark', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 40, ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'HorizontalAlign' => array( 'type' => 'string', ), 'HorizontalOffset' => array( 'type' => 'string', ), 'VerticalAlign' => array( 'type' => 'string', ), 'VerticalOffset' => array( 'type' => 'string', ), 'Opacity' => array( 'type' => 'string', ), 'Target' => array( 'type' => 'string', ), ), ), ), ), ), 'Audio' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'SampleRate' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'Channels' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'properties' => array( 'Profile' => array( 'type' => 'string', ), ), ), ), ), 'Thumbnails' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Too many operations for a given AWS account. For example, the number of pipelines exceeds the maximum allowed.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'DeletePipeline' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-09-25/pipelines/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'DeletePreset' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-09-25/presets/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ListJobsByPipeline' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/jobsByPipeline/{PipelineId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListJobsByPipelineResponse', 'responseType' => 'model', 'parameters' => array( 'PipelineId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Ascending' => array( 'type' => 'string', 'location' => 'query', ), 'PageToken' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ListJobsByStatus' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/jobsByStatus/{Status}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListJobsByStatusResponse', 'responseType' => 'model', 'parameters' => array( 'Status' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Ascending' => array( 'type' => 'string', 'location' => 'query', ), 'PageToken' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ListPipelines' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/pipelines', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListPipelinesResponse', 'responseType' => 'model', 'parameters' => array( 'Ascending' => array( 'type' => 'string', 'location' => 'query', ), 'PageToken' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ListPresets' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/presets', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListPresetsResponse', 'responseType' => 'model', 'parameters' => array( 'Ascending' => array( 'type' => 'string', 'location' => 'query', ), 'PageToken' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ReadJob' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/jobs/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ReadJobResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ReadPipeline' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/pipelines/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ReadPipelineResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'ReadPreset' => array( 'httpMethod' => 'GET', 'uri' => '/2012-09-25/presets/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ReadPresetResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'TestRole' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/roleTests', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'TestRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Role' => array( 'type' => 'string', 'location' => 'json', ), 'InputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'OutputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'Topics' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 30, 'items' => array( 'name' => 'SnsTopic', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'UpdatePipeline' => array( 'httpMethod' => 'PUT', 'uri' => '/2012-09-25/pipelines/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdatePipelineResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 40, ), 'InputBucket' => array( 'type' => 'string', 'location' => 'json', ), 'Role' => array( 'type' => 'string', 'location' => 'json', ), 'Notifications' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Access' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 255, ), 'Access' => array( 'type' => 'array', 'maxItems' => 30, 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'UpdatePipelineNotifications' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/pipelines/{Id}/notifications', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdatePipelineNotificationsResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Notifications' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), 'UpdatePipelineStatus' => array( 'httpMethod' => 'POST', 'uri' => '/2012-09-25/pipelines/{Id}/status', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UpdatePipelineStatusResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Status' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameter values were not provided in the request.', 'class' => 'ValidationException', ), array( 'class' => 'IncompatibleVersionException', ), array( 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', 'class' => 'ResourceInUseException', ), array( 'reason' => 'General authentication failure. The request was not signed correctly.', 'class' => 'AccessDeniedException', ), array( 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', 'class' => 'InternalServiceException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreateJobResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Job' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'PipelineId' => array( 'type' => 'string', ), 'Input' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'JobOutput', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', ), 'Playlists' => array( 'type' => 'array', 'items' => array( 'name' => 'Playlist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), ), ), ), ), 'CreatePipelineResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'CreatePresetResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Preset' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), 'Audio' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'SampleRate' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'Channels' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'properties' => array( 'Profile' => array( 'type' => 'string', ), ), ), ), ), 'Video' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'KeyframesMaxDist' => array( 'type' => 'string', ), 'FixedGOP' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'MaxFrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'DisplayAspectRatio' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'PresetWatermark', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'HorizontalAlign' => array( 'type' => 'string', ), 'HorizontalOffset' => array( 'type' => 'string', ), 'VerticalAlign' => array( 'type' => 'string', ), 'VerticalOffset' => array( 'type' => 'string', ), 'Opacity' => array( 'type' => 'string', ), 'Target' => array( 'type' => 'string', ), ), ), ), ), ), 'Thumbnails' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), ), ), 'Type' => array( 'type' => 'string', ), ), ), 'Warning' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListJobsByPipelineResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Jobs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Job', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'PipelineId' => array( 'type' => 'string', ), 'Input' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'JobOutput', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', ), 'Playlists' => array( 'type' => 'array', 'items' => array( 'name' => 'Playlist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), ), ), ), 'NextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListJobsByStatusResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Jobs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Job', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'PipelineId' => array( 'type' => 'string', ), 'Input' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'JobOutput', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', ), 'Playlists' => array( 'type' => 'array', 'items' => array( 'name' => 'Playlist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), ), ), ), 'NextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListPipelinesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipelines' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Pipeline', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), 'NextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListPresetsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Presets' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Preset', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), 'Audio' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'SampleRate' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'Channels' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'properties' => array( 'Profile' => array( 'type' => 'string', ), ), ), ), ), 'Video' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'KeyframesMaxDist' => array( 'type' => 'string', ), 'FixedGOP' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'MaxFrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'DisplayAspectRatio' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'PresetWatermark', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'HorizontalAlign' => array( 'type' => 'string', ), 'HorizontalOffset' => array( 'type' => 'string', ), 'VerticalAlign' => array( 'type' => 'string', ), 'VerticalOffset' => array( 'type' => 'string', ), 'Opacity' => array( 'type' => 'string', ), 'Target' => array( 'type' => 'string', ), ), ), ), ), ), 'Thumbnails' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), ), ), 'Type' => array( 'type' => 'string', ), ), ), ), 'NextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ReadJobResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Job' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'PipelineId' => array( 'type' => 'string', ), 'Input' => array( 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'Interlaced' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), ), ), 'Output' => array( 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Outputs' => array( 'type' => 'array', 'items' => array( 'name' => 'JobOutput', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'ThumbnailPattern' => array( 'type' => 'string', ), 'Rotate' => array( 'type' => 'string', ), 'PresetId' => array( 'type' => 'string', ), 'SegmentDuration' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'Width' => array( 'type' => 'numeric', ), 'Height' => array( 'type' => 'numeric', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'JobWatermark', 'type' => 'object', 'properties' => array( 'PresetWatermarkId' => array( 'type' => 'string', ), 'InputKey' => array( 'type' => 'string', ), ), ), ), 'AlbumArt' => array( 'type' => 'object', 'properties' => array( 'MergePolicy' => array( 'type' => 'string', ), 'Artwork' => array( 'type' => 'array', 'items' => array( 'name' => 'Artwork', 'type' => 'object', 'properties' => array( 'InputKey' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'AlbumArtFormat' => array( 'type' => 'string', ), ), ), ), ), ), 'Composition' => array( 'type' => 'array', 'items' => array( 'name' => 'Clip', 'type' => 'object', 'properties' => array( 'TimeSpan' => array( 'type' => 'object', 'properties' => array( 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'OutputKeyPrefix' => array( 'type' => 'string', ), 'Playlists' => array( 'type' => 'array', 'items' => array( 'name' => 'Playlist', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Format' => array( 'type' => 'string', ), 'OutputKeys' => array( 'type' => 'array', 'items' => array( 'name' => 'Key', 'type' => 'string', ), ), 'Status' => array( 'type' => 'string', ), 'StatusDetail' => array( 'type' => 'string', ), ), ), ), 'Status' => array( 'type' => 'string', ), ), ), ), ), 'ReadPipelineResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'ReadPresetResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Preset' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Container' => array( 'type' => 'string', ), 'Audio' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'SampleRate' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'Channels' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'properties' => array( 'Profile' => array( 'type' => 'string', ), ), ), ), ), 'Video' => array( 'type' => 'object', 'properties' => array( 'Codec' => array( 'type' => 'string', ), 'CodecOptions' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'KeyframesMaxDist' => array( 'type' => 'string', ), 'FixedGOP' => array( 'type' => 'string', ), 'BitRate' => array( 'type' => 'string', ), 'FrameRate' => array( 'type' => 'string', ), 'MaxFrameRate' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'DisplayAspectRatio' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), 'Watermarks' => array( 'type' => 'array', 'items' => array( 'name' => 'PresetWatermark', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'HorizontalAlign' => array( 'type' => 'string', ), 'HorizontalOffset' => array( 'type' => 'string', ), 'VerticalAlign' => array( 'type' => 'string', ), 'VerticalOffset' => array( 'type' => 'string', ), 'Opacity' => array( 'type' => 'string', ), 'Target' => array( 'type' => 'string', ), ), ), ), ), ), 'Thumbnails' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'Interval' => array( 'type' => 'string', ), 'Resolution' => array( 'type' => 'string', ), 'AspectRatio' => array( 'type' => 'string', ), 'MaxWidth' => array( 'type' => 'string', ), 'MaxHeight' => array( 'type' => 'string', ), 'SizingPolicy' => array( 'type' => 'string', ), 'PaddingPolicy' => array( 'type' => 'string', ), ), ), 'Type' => array( 'type' => 'string', ), ), ), ), ), 'TestRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Success' => array( 'type' => 'string', 'location' => 'json', ), 'Messages' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'UpdatePipelineResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'UpdatePipelineNotificationsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), 'UpdatePipelineStatusResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Pipeline' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'InputBucket' => array( 'type' => 'string', ), 'OutputBucket' => array( 'type' => 'string', ), 'Role' => array( 'type' => 'string', ), 'Notifications' => array( 'type' => 'object', 'properties' => array( 'Progressing' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'string', ), 'Warning' => array( 'type' => 'string', ), 'Error' => array( 'type' => 'string', ), ), ), 'ContentConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), 'ThumbnailConfig' => array( 'type' => 'object', 'properties' => array( 'Bucket' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'Permissions' => array( 'type' => 'array', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'GranteeType' => array( 'type' => 'string', ), 'Grantee' => array( 'type' => 'string', ), 'Access' => array( 'type' => 'array', 'items' => array( 'name' => 'AccessControl', 'type' => 'string', ), ), ), ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'ListJobsByPipeline' => array( 'token_param' => 'PageToken', 'token_key' => 'NextPageToken', 'result_key' => 'Jobs', ), 'ListJobsByStatus' => array( 'token_param' => 'PageToken', 'token_key' => 'NextPageToken', 'result_key' => 'Jobs', ), 'ListPipelines' => array( 'token_param' => 'PageToken', 'token_key' => 'NextPageToken', 'result_key' => 'Pipelines', ), 'ListPresets' => array( 'token_param' => 'PageToken', 'token_key' => 'NextPageToken', 'result_key' => 'Presets', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/emr-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } '2009-03-31', 'endpointPrefix' => 'elasticmapreduce', 'serviceFullName' => 'Amazon Elastic MapReduce', 'serviceAbbreviation' => 'Amazon EMR', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'ElasticMapReduce.', 'timestampFormat' => 'unixTimestamp', 'signatureVersion' => 'v4', 'namespace' => 'Emr', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'elasticmapreduce.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AddInstanceGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddInstanceGroupsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.AddInstanceGroups', ), 'InstanceGroups' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'InstanceGroupConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', 'maxLength' => 256, ), 'Market' => array( 'type' => 'string', ), 'InstanceRole' => array( 'required' => true, 'type' => 'string', ), 'BidPrice' => array( 'type' => 'string', 'maxLength' => 256, ), 'InstanceType' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'InstanceCount' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), 'JobFlowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'AddJobFlowSteps' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddJobFlowStepsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.AddJobFlowSteps', ), 'JobFlowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'Steps' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StepConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'maxLength' => 256, ), 'ActionOnFailure' => array( 'type' => 'string', ), 'HadoopJarStep' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Properties' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyValue', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', 'maxLength' => 10280, ), 'Value' => array( 'type' => 'string', 'maxLength' => 10280, ), ), ), ), 'Jar' => array( 'required' => true, 'type' => 'string', 'maxLength' => 10280, ), 'MainClass' => array( 'type' => 'string', 'maxLength' => 10280, ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'AddTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.AddTags', ), 'ResourceId' => array( 'type' => 'string', 'location' => 'json', ), 'Tags' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'DescribeCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeClusterOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.DescribeCluster', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'DescribeJobFlows' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeJobFlowsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.DescribeJobFlows', ), 'CreatedAfter' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', 'location' => 'json', ), 'CreatedBefore' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', 'location' => 'json', ), 'JobFlowIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), 'JobFlowStates' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'JobFlowExecutionState', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeStep' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStepOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.DescribeStep', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'StepId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListBootstrapActions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListBootstrapActionsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListBootstrapActions', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListClusters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListClustersOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListClusters', ), 'CreatedAfter' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', 'location' => 'json', ), 'CreatedBefore' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', 'location' => 'json', ), 'ClusterStates' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ClusterState', 'type' => 'string', ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListInstanceGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListInstanceGroupsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListInstanceGroups', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListInstancesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListInstances', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceGroupId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceGroupTypes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'InstanceGroupType', 'type' => 'string', ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ListSteps' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListStepsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ListSteps', ), 'ClusterId' => array( 'type' => 'string', 'location' => 'json', ), 'StepStates' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StepState', 'type' => 'string', ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'ModifyInstanceGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.ModifyInstanceGroups', ), 'InstanceGroups' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'InstanceGroupModifyConfig', 'type' => 'object', 'properties' => array( 'InstanceGroupId' => array( 'required' => true, 'type' => 'string', 'maxLength' => 256, ), 'InstanceCount' => array( 'type' => 'numeric', ), 'EC2InstanceIdsToTerminate' => array( 'type' => 'array', 'items' => array( 'name' => 'InstanceId', 'type' => 'string', ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'RemoveTags' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.RemoveTags', ), 'ResourceId' => array( 'type' => 'string', 'location' => 'json', ), 'TagKeys' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', 'class' => 'InternalServerException', ), array( 'reason' => 'This exception occurs when there is something wrong with user input.', 'class' => 'InvalidRequestException', ), ), ), 'RunJobFlow' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RunJobFlowOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.RunJobFlow', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'LogUri' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 10280, ), 'AdditionalInfo' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 10280, ), 'AmiVersion' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'Instances' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'MasterInstanceType' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'SlaveInstanceType' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'InstanceCount' => array( 'type' => 'numeric', ), 'InstanceGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'InstanceGroupConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', 'maxLength' => 256, ), 'Market' => array( 'type' => 'string', ), 'InstanceRole' => array( 'required' => true, 'type' => 'string', ), 'BidPrice' => array( 'type' => 'string', 'maxLength' => 256, ), 'InstanceType' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'InstanceCount' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), 'Ec2KeyName' => array( 'type' => 'string', 'maxLength' => 256, ), 'Placement' => array( 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'required' => true, 'type' => 'string', 'maxLength' => 10280, ), ), ), 'KeepJobFlowAliveWhenNoSteps' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'TerminationProtected' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'HadoopVersion' => array( 'type' => 'string', 'maxLength' => 256, ), 'Ec2SubnetId' => array( 'type' => 'string', 'maxLength' => 256, ), ), ), 'Steps' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StepConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'maxLength' => 256, ), 'ActionOnFailure' => array( 'type' => 'string', ), 'HadoopJarStep' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Properties' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyValue', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', 'maxLength' => 10280, ), 'Value' => array( 'type' => 'string', 'maxLength' => 10280, ), ), ), ), 'Jar' => array( 'required' => true, 'type' => 'string', 'maxLength' => 10280, ), 'MainClass' => array( 'type' => 'string', 'maxLength' => 10280, ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), ), ), ), ), 'BootstrapActions' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'BootstrapActionConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'maxLength' => 256, ), 'ScriptBootstrapAction' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Path' => array( 'required' => true, 'type' => 'string', 'maxLength' => 10280, ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), ), ), ), ), 'SupportedProducts' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlStringMaxLen256', 'type' => 'string', 'maxLength' => 256, ), ), 'NewSupportedProducts' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'SupportedProductConfig', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', 'maxLength' => 256, ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), ), ), 'VisibleToAllUsers' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'JobFlowRole' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 10280, ), 'Tags' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'SetTerminationProtection' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.SetTerminationProtection', ), 'JobFlowIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), 'TerminationProtected' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'SetVisibleToAllUsers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.SetVisibleToAllUsers', ), 'JobFlowIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), 'VisibleToAllUsers' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), 'TerminateJobFlows' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'ElasticMapReduce.TerminateJobFlows', ), 'JobFlowIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlString', 'type' => 'string', 'maxLength' => 10280, ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', 'class' => 'InternalServerErrorException', ), ), ), ), 'models' => array( 'AddInstanceGroupsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobFlowId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceGroupIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlStringMaxLen256', 'type' => 'string', ), ), ), ), 'AddJobFlowStepsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StepIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'XmlStringMaxLen256', 'type' => 'string', ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeClusterOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Cluster' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), 'Ec2InstanceAttributes' => array( 'type' => 'object', 'properties' => array( 'Ec2KeyName' => array( 'type' => 'string', ), 'Ec2SubnetId' => array( 'type' => 'string', ), 'Ec2AvailabilityZone' => array( 'type' => 'string', ), 'IamInstanceProfile' => array( 'type' => 'string', ), ), ), 'LogUri' => array( 'type' => 'string', ), 'RequestedAmiVersion' => array( 'type' => 'string', ), 'RunningAmiVersion' => array( 'type' => 'string', ), 'AutoTerminate' => array( 'type' => 'boolean', ), 'TerminationProtected' => array( 'type' => 'boolean', ), 'VisibleToAllUsers' => array( 'type' => 'boolean', ), 'Applications' => array( 'type' => 'array', 'items' => array( 'name' => 'Application', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'AdditionalInfo' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), ), ), ), 'Tags' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DescribeJobFlowsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobFlows' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'JobFlowDetail', 'type' => 'object', 'properties' => array( 'JobFlowId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'LogUri' => array( 'type' => 'string', ), 'AmiVersion' => array( 'type' => 'string', ), 'ExecutionStatusDetail' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), 'LastStateChangeReason' => array( 'type' => 'string', ), ), ), 'Instances' => array( 'type' => 'object', 'properties' => array( 'MasterInstanceType' => array( 'type' => 'string', ), 'MasterPublicDnsName' => array( 'type' => 'string', ), 'MasterInstanceId' => array( 'type' => 'string', ), 'SlaveInstanceType' => array( 'type' => 'string', ), 'InstanceCount' => array( 'type' => 'numeric', ), 'InstanceGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'InstanceGroupDetail', 'type' => 'object', 'properties' => array( 'InstanceGroupId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Market' => array( 'type' => 'string', ), 'InstanceRole' => array( 'type' => 'string', ), 'BidPrice' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'InstanceRequestCount' => array( 'type' => 'numeric', ), 'InstanceRunningCount' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'LastStateChangeReason' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), 'NormalizedInstanceHours' => array( 'type' => 'numeric', ), 'Ec2KeyName' => array( 'type' => 'string', ), 'Ec2SubnetId' => array( 'type' => 'string', ), 'Placement' => array( 'type' => 'object', 'properties' => array( 'AvailabilityZone' => array( 'type' => 'string', ), ), ), 'KeepJobFlowAliveWhenNoSteps' => array( 'type' => 'boolean', ), 'TerminationProtected' => array( 'type' => 'boolean', ), 'HadoopVersion' => array( 'type' => 'string', ), ), ), 'Steps' => array( 'type' => 'array', 'items' => array( 'name' => 'StepDetail', 'type' => 'object', 'properties' => array( 'StepConfig' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ActionOnFailure' => array( 'type' => 'string', ), 'HadoopJarStep' => array( 'type' => 'object', 'properties' => array( 'Properties' => array( 'type' => 'array', 'items' => array( 'name' => 'KeyValue', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'Jar' => array( 'type' => 'string', ), 'MainClass' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), ), ), ), ), 'ExecutionStatusDetail' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), 'LastStateChangeReason' => array( 'type' => 'string', ), ), ), ), ), ), 'BootstrapActions' => array( 'type' => 'array', 'items' => array( 'name' => 'BootstrapActionDetail', 'type' => 'object', 'properties' => array( 'BootstrapActionConfig' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ScriptBootstrapAction' => array( 'type' => 'object', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlString', 'type' => 'string', ), ), ), ), ), ), ), ), ), 'SupportedProducts' => array( 'type' => 'array', 'items' => array( 'name' => 'XmlStringMaxLen256', 'type' => 'string', ), ), 'VisibleToAllUsers' => array( 'type' => 'boolean', ), 'JobFlowRole' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeStepOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Step' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Config' => array( 'type' => 'object', 'properties' => array( 'Jar' => array( 'type' => 'string', ), 'Properties' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'MainClass' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'ActionOnFailure' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ListBootstrapActionsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'BootstrapActions' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Command', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ScriptPath' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListClustersOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Clusters' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ClusterSummary', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListInstanceGroupsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceGroups' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'InstanceGroup', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Market' => array( 'type' => 'string', ), 'InstanceGroupType' => array( 'type' => 'string', ), 'BidPrice' => array( 'type' => 'string', ), 'InstanceType' => array( 'type' => 'string', ), 'RequestedInstanceCount' => array( 'type' => 'numeric', ), 'RunningInstanceCount' => array( 'type' => 'numeric', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListInstancesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Instances' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Ec2InstanceId' => array( 'type' => 'string', ), 'PublicDnsName' => array( 'type' => 'string', ), 'PublicIpAddress' => array( 'type' => 'string', ), 'PrivateDnsName' => array( 'type' => 'string', ), 'PrivateIpAddress' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'ReadyDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListStepsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Steps' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StepSummary', 'type' => 'object', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'object', 'properties' => array( 'State' => array( 'type' => 'string', ), 'StateChangeReason' => array( 'type' => 'object', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), 'Timeline' => array( 'type' => 'object', 'properties' => array( 'CreationDateTime' => array( 'type' => 'string', ), 'StartDateTime' => array( 'type' => 'string', ), 'EndDateTime' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'RunJobFlowOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobFlowId' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeJobFlows' => array( 'result_key' => 'JobFlows', ), 'ListBootstrapActions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'BootstrapActions', ), 'ListClusters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'Clusters', ), 'ListInstanceGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'InstanceGroups', ), 'ListInstances' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'Instances', ), 'ListSteps' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'result_key' => 'Steps', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/glacier-%s.php', // Set default value for "accountId" for all requests 'command.params' => array( 'accountId' => '-', Options::MODEL_PROCESSING => true ) )) ->setExceptionParser(new JsonRestExceptionParser()) ->setIteratorsConfig(array( 'limit_param' => 'limit', 'token_param' => 'marker', 'token_key' => 'Marker', 'operations' => array( 'ListJobs' => array( 'result_key' => 'JobList' ), 'ListMultipartUploads' => array( 'result_key' => 'UploadsList' ), 'ListParts' => array( 'result_key' => 'Parts' ), 'ListVaults' => array( 'result_key' => 'VaultList' ) ) )) ->build(); // Add the Glacier version header required for all operations $client->getConfig()->setPath( 'request.options/headers/x-amz-glacier-version', $client->getDescription()->getApiVersion() ); // Allow for specifying bodies with file paths and file handles $uploadOperations = array('UploadArchive', 'UploadMultipartPart'); $client->addSubscriber(new UploadBodyListener($uploadOperations, 'body', 'sourceFile')); // Listen for upload operations and make sure the required hash headers are added $client->addSubscriber(new GlacierUploadListener()); return $client; } } array('onCommandBeforeSend'), ); } /** * Retrieve bodies passed in as UploadPartContext objects and set the real hash, length, etc. values on the command * * @param Event $event Event emitted */ public function onCommandBeforeSend(Event $event) { /** @var $command AbstractCommand */ $command = $event['command']; $contentHash = $command->get('ContentSHA256'); if ($contentHash === true) { /** @var $request EntityEnclosingRequest */ $request = $command->getRequest(); $upload = UploadPartGenerator::createSingleUploadPart($request->getBody()); $request->addHeader('x-amz-content-sha256', $upload->getContentHash()); if (!$command->get('checksum')) { $request->addHeader('x-amz-sha256-tree-hash', $upload->getChecksum()); } } elseif (is_string($contentHash)) { $request = $command->getRequest(); $request->addHeader('x-amz-content-sha256', $contentHash); } } } state->getPartGenerator()->getPartSize(); } /** * {@inheritdoc} */ protected function complete() { $partGenerator = $this->state->getPartGenerator(); $params = array_replace($this->state->getUploadId()->toParams(), array( 'archiveSize' => $partGenerator->getArchiveSize(), 'checksum' => $partGenerator->getRootChecksum(), Ua::OPTION => Ua::MULTIPART_UPLOAD )); $command = $this->client->getCommand('CompleteMultipartUpload', $params); return $command->getResult(); } /** * {@inheritdoc} */ protected function getAbortCommand() { $params = $this->state->getUploadId()->toParams(); $params[Ua::OPTION] = Ua::MULTIPART_UPLOAD; /** @var $command OperationCommand */ $command = $this->client->getCommand('AbortMultipartUpload', $params); return $command; } /** * Creates an UploadMultipartPart command from an UploadPart object * * @param UploadPart $part UploadPart for which to create a command * @param bool $useSourceCopy Whether or not to use the original source or a copy of it * * @return OperationCommand */ protected function getCommandForPart(UploadPart $part, $useSourceCopy = false) { // Setup the command with identifying parameters (accountId, vaultName, and uploadId) /** @var $command OperationCommand */ $command = $this->client->getCommand('UploadMultipartPart', $this->state->getUploadId()->toParams()); $command->set(Ua::OPTION, Ua::MULTIPART_UPLOAD); // Get the correct source $source = $this->source; if ($useSourceCopy) { $sourceUri = $this->source->getUri(); $source = new EntityBody(fopen($sourceUri, 'r')); } // Add the range, checksum, and the body limited by the range $command->set('range', $part->getFormattedRange()); $command->set('checksum', $part->getChecksum()); $command->set('ContentSHA256', $part->getContentHash()); $command->set('body', new ReadLimitEntityBody($source, $part->getSize(), $part->getOffset())); return $command; } } source->isLocal() || $this->source->getWrapper() != 'plainfile') { throw new RuntimeException('The source data must be a local file stream when uploading in parallel.'); } if (empty($this->options['concurrency'])) { throw new RuntimeException('The `concurrency` option must be specified when instantiating.'); } } /** * {@inheritdoc} */ protected function transfer() { /** @var $parts UploadPartGenerator */ $parts = $this->state->getPartGenerator(); $chunkSize = min($this->options['concurrency'], count($parts)); $partSets = new ChunkedIterator($parts, $chunkSize); foreach ($partSets as $partSet) { /** @var $part UploadPart */ $commands = array(); foreach ($partSet as $index => $part) { $command = $this->getCommandForPart($part, (bool) $index)->set('part', $part); $this->dispatch(self::BEFORE_PART_UPLOAD, $this->getEventData($command)); $commands[] = $command; } // Allow listeners to stop the transfer if needed if ($this->stopped) { break; } // Execute each command, iterate over the results, and add to the transfer state /** @var $command \Guzzle\Service\Command\OperationCommand */ foreach ($this->client->execute($commands) as $command) { $this->state->addPart($command->get('part')); $this->dispatch(self::AFTER_PART_UPLOAD, $this->getEventData($command)); } } } } state->getPartGenerator(); /** @var $part UploadPart */ foreach ($partGenerator as $part) { $command = $this->getCommandForPart($part); // Notify observers that the part is about to be uploaded $eventData = $this->getEventData($command); $this->dispatch(self::BEFORE_PART_UPLOAD, $eventData); // Allow listeners to stop the transfer if needed if ($this->stopped) { break; } $command->execute(); $this->state->addPart($part); // Notify observers that the part was uploaded $this->dispatch(self::AFTER_PART_UPLOAD, $eventData); } } } getIterator('ListParts', $uploadId->toParams()); foreach ($listParts as $part) { list($firstByte, $lastByte) = explode('-', $part['RangeInBytes']); $partSize = (float) $listParts->getLastResult()->get('PartSizeInBytes'); $partData = array( 'partNumber' => $firstByte / $partSize + 1, 'checksum' => $part['SHA256TreeHash'], 'contentHash' => self::ALREADY_UPLOADED, 'size' => $lastByte - $firstByte + 1, 'offset' => $firstByte ); $transferState->addPart(UploadPart::fromArray($partData)); } return $transferState; } /** * @param UploadPartGenerator $partGenerator Glacier upload helper object * * @return self */ public function setPartGenerator(UploadPartGenerator $partGenerator) { $this->partGenerator = $partGenerator; return $this; } /** * @return UploadPartGenerator Glacier upload helper object */ public function getPartGenerator() { return $this->partGenerator; } } accountId = $accountId; return $this; } /** * Set the vault name to upload the part to * * @param string $vaultName Name of the vault * * @return self */ public function setVaultName($vaultName) { $this->vaultName = $vaultName; return $this; } /** * Set the upload part size * * @param int $partSize Upload part size * * @return self */ public function setPartSize($partSize) { $this->partSize = (int) $partSize; return $this; } /** * Set the archive description * * @param string $archiveDescription Archive description * * @return self */ public function setArchiveDescription($archiveDescription) { $this->archiveDescription = $archiveDescription; return $this; } /** * Set the concurrency level to use when uploading parts. This affects how many parts are uploaded in parallel. You * must use a local file as your data source when using a concurrency greater than 1 * * @param int $concurrency Concurrency level * * @return self */ public function setConcurrency($concurrency) { $this->concurrency = $concurrency; return $this; } /** * Sets the Glacier upload helper object that pre-calculates hashes and sizes for all upload parts * * @param UploadPartGenerator $partGenerator Glacier upload helper object * * @return self */ public function setPartGenerator(UploadPartGenerator $partGenerator) { $this->partGenerator = $partGenerator; return $this; } /** * {@inheritdoc} * @throws InvalidArgumentException when attempting to resume a transfer using a non-seekable stream * @throws InvalidArgumentException when missing required properties (bucket, key, client, source) */ public function build() { // If a Glacier upload helper object was set, use the source and part size from it if ($this->partGenerator) { $this->partSize = $this->partGenerator->getPartSize(); } if (!($this->state instanceof State) && !$this->vaultName || !$this->client || !$this->source) { throw new InvalidArgumentException('You must specify a vault name, client, and source.'); } if (!$this->source->isSeekable()) { throw new InvalidArgumentException('You cannot upload from a non-seekable source.'); } // If no state was set, then create one by initiating or loading a multipart upload if (is_string($this->state)) { if (!$this->partGenerator) { throw new InvalidArgumentException('You must provide an UploadPartGenerator when resuming an upload.'); } /** @var $state \Aws\Glacier\Model\MultipartUpload\TransferState */ $this->state = TransferState::fromUploadId($this->client, UploadId::fromParams(array( 'accountId' => $this->accountId, 'vaultName' => $this->vaultName, 'uploadId' => $this->state ))); $this->state->setPartGenerator($this->partGenerator); } elseif (!$this->state) { $this->state = $this->initiateMultipartUpload(); } $options = array( 'concurrency' => $this->concurrency ); return $this->concurrency > 1 ? new ParallelTransfer($this->client, $this->state, $this->source, $options) : new SerialTransfer($this->client, $this->state, $this->source, $options); } /** * {@inheritdoc} */ protected function initiateMultipartUpload() { $params = array( 'accountId' => $this->accountId, 'vaultName' => $this->vaultName ); $partGenerator = $this->partGenerator ?: UploadPartGenerator::factory($this->source, $this->partSize); $command = $this->client->getCommand('InitiateMultipartUpload', array_replace($params, array( 'command.headers' => $this->headers, 'partSize' => $partGenerator->getPartSize(), 'archiveDescription' => $this->archiveDescription, Ua::OPTION => Ua::MULTIPART_UPLOAD ))); $params['uploadId'] = $command->getResult()->get('uploadId'); // Create a new state based on the initiated upload $state = new TransferState(UploadId::fromParams($params)); $state->setPartGenerator($partGenerator); return $state; } } '-', 'uploadId' => false, 'vaultName' => false ); } 'partNumber', 'checksum' => 'checksum', 'contentHash' => 'contentHash', 'size' => 'size', 'offset' => 'offset' ); /** * @var string The sha256 tree hash of the upload body */ protected $checksum; /** * @var string The sha256 linear hash of the upload body */ protected $contentHash; /** * @var int The size (or content-length) in bytes of the upload body */ protected $size; /** * @var int The starting offset byte of the upload body */ protected $offset; /** * @return string */ public function getChecksum() { return $this->checksum; } /** * @return string */ public function getContentHash() { return $this->contentHash; } /** * @return int */ public function getSize() { return $this->size; } /** * @return int */ public function getOffset() { return $this->offset; } /** * Returns the byte range of the part as an array * * @return array */ public function getRange() { return array($this->offset, $this->offset + $this->size - 1); } /** * Returns the byte range ot the part formatted for the Content-Range header * * @return string */ public function getFormattedRange() { list($firstByte, $lastByte) = $this->getRange(); return "bytes {$firstByte}-{$lastByte}/*"; } } maxSize = $maxSize; $this->offset = $offset; $this->size = 0; $this->treeHash = new TreeHash(); $this->chunkHash = new ChunkHash(); } /** * Adds data to the context. This adds data to both the tree and chunk hashes and increases the size * * @param string $data Data to add to the context * * @return self * @throws LogicException when the context is already finalized */ public function addData($data) { $size = strlen($data); if ($this->size + $size > $this->maxSize) { throw new LogicException('You cannot add data that will exceed the maximum size of this upload.'); } try { $this->treeHash->addData($data); $this->chunkHash->addData($data); $this->size += $size; } catch (LogicException $e) { throw new LogicException('You cannot add data to a finalized UploadPartContext.', 0, $e); } return $this; } /** * Finalizes the context by calculating the final hashes and generates an upload part object * * @return UploadPart */ public function generatePart() { if (!$this->uploadPart) { $this->uploadPart = UploadPart::fromArray(array( 'partNumber' => (int) ($this->offset / $this->maxSize + 1), 'checksum' => $this->treeHash->getHash(), 'contentHash' => $this->chunkHash->getHash(), 'size' => $this->size, 'offset' => $this->offset )); } return $this->uploadPart; } /** * Checks if the size of the context is the same as the maximum size * * @return bool */ public function isFull() { return $this->size === $this->maxSize; } /** * Checks if the size of the context is 0 * * @return bool */ public function isEmpty() { return $this->size === 0; } } 1) { // @codeCoverageIgnoreStart throw new RuntimeException('You cannot create a single upload that is larger than 4 GB.'); // @codeCoverageIgnoreEnd } return $generator->getUploadPart(1); } /** * @param EntityBodyInterface $body The upload body * @param int $partSize The size of parts to split the upload into. Default is the 4GB max * * @throws InvalidArgumentException when the part size is invalid (i.e. not a power of 2 of 1MB) * @throws InvalidArgumentException when the body is not seekable (must be able to rewind after calculating hashes) * @throws InvalidArgumentException when the archive size is less than one byte */ public function __construct(EntityBodyInterface $body, $partSize) { $this->partSize = $partSize; // Make sure the part size is valid $validPartSizes = array_map(function ($value) {return pow(2, $value) * Size::MB;}, range(0, 12)); if (!in_array($this->partSize, $validPartSizes)) { throw new InvalidArgumentException('The part size must be a megabyte multiplied by a power of 2 and no ' . 'greater than 4 gigabytes.'); } // Validate body if (!$body->isSeekable()) { throw new InvalidArgumentException('The upload body must be seekable.'); } $this->generateUploadParts($body); // Validate archive size if ($this->archiveSize < 1) { throw new InvalidArgumentException('The archive size must be at least 1 byte.'); } } /** * Returns a single upload part from the calculated uploads by part number. By default it returns the first, which * is useful behavior if there is only one upload. * * @param int $partNumber The numerical index of the upload * * @return UploadPart * @throws OutOfBoundsException if the index of the upload doesn't exist */ public function getUploadPart($partNumber) { $partNumber = (int) $partNumber; // Get the upload at the index if it exists if (isset($this->uploadParts[$partNumber - 1])) { return $this->uploadParts[$partNumber - 1]; } else { throw new OutOfBoundsException("An upload part with part number {$partNumber} at index did not exist."); } } /** * @return array */ public function getAllParts() { return $this->uploadParts; } /** * @return array */ public function getArchiveSize() { return $this->archiveSize; } /** * @return string */ public function getRootChecksum() { if (!$this->rootChecksum) { $this->rootChecksum = TreeHash::fromChecksums(array_map(function (UploadPart $part) { return $part->getChecksum(); }, $this->uploadParts))->getHash(); } return $this->rootChecksum; } /** * @return string */ public function getPartSize() { return $this->partSize; } /** * {@inheritdoc} */ public function serialize() { return serialize(array( 'uploadParts' => $this->uploadParts, 'archiveSize' => $this->archiveSize, 'partSize' => $this->partSize )); } /** * {@inheritdoc} */ public function unserialize($serialized) { // Unserialize data $data = unserialize($serialized); // Set properties foreach (array('uploadParts', 'archiveSize', 'partSize') as $property) { if (isset($data[$property])) { $this->{$property} = $data[$property]; } else { throw new RuntimeException(sprintf('Cannot unserialize the %s class. The %s property is missing.', __CLASS__, $property )); } } } /** * {@inheritdoc} */ public function getIterator() { return new \ArrayIterator($this->uploadParts); } /** * {@inheritdoc} */ public function count() { return count($this->uploadParts); } /** * Performs the work of reading the body stream, creating tree hashes, and creating UploadPartContext objects * * @param EntityBodyInterface $body The body to create parts from */ protected function generateUploadParts(EntityBodyInterface $body) { // Rewind the body stream $body->seek(0); // Initialize variables for tracking data for upload $uploadContext = new UploadPartContext($this->partSize, $body->ftell()); // Read the data from the streamed body in 1MB chunks while ($data = $body->read(min($this->partSize, Size::MB))) { // Add data to the hashes and size calculations $uploadContext->addData($data); // If the upload part is complete, generate an upload object and reset the currently tracked upload data if ($uploadContext->isFull()) { $this->updateTotals($uploadContext->generatePart()); $uploadContext = new UploadPartContext($this->partSize, $body->ftell()); } } // Handle any leftover data if (!$uploadContext->isEmpty()) { $this->updateTotals($uploadContext->generatePart()); } // Rewind the body stream $body->seek(0); } /** * Updated the upload helper running totals and tree hash with the data from a complete upload part * * @param UploadPart $part The newly completed upload part * * @throws OverflowException if the maximum number of allowed upload parts is exceeded */ protected function updateTotals(UploadPart $part) { // Throw an exception if there are more parts than total allowed if ($part->getPartNumber() > self::MAX_NUM_PARTS) { // @codeCoverageIgnoreStart throw new OverflowException('An archive must be uploaded in ' . self::MAX_NUM_PARTS . ' parts or less.'); // @codeCoverageIgnoreEnd } $this->uploadParts[] = $part; $this->archiveSize += $part->getSize(); } } '2012-06-01', 'endpointPrefix' => 'glacier', 'serviceFullName' => 'Amazon Glacier', 'serviceType' => 'rest-json', 'signatureVersion' => 'v4', 'namespace' => 'Glacier', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.eu-west-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.ap-southeast-2.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.ap-northeast-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'glacier.cn-north-1.amazonaws.com.cn', ), ), 'operations' => array( 'AbortMultipartUpload' => array( 'httpMethod' => 'DELETE', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'uploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'CompleteMultipartUpload' => array( 'httpMethod' => 'POST', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ArchiveCreationOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'uploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'archiveSize' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-size', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'CreateVault' => array( 'httpMethod' => 'PUT', 'uri' => '/{accountId}/vaults/{vaultName}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateVaultOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), array( 'reason' => 'Returned if the request results in a vault or account limit being exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteArchive' => array( 'httpMethod' => 'DELETE', 'uri' => '/{accountId}/vaults/{vaultName}/archives/{archiveId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'archiveId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'DeleteVault' => array( 'httpMethod' => 'DELETE', 'uri' => '/{accountId}/vaults/{vaultName}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'DeleteVaultNotifications' => array( 'httpMethod' => 'DELETE', 'uri' => '/{accountId}/vaults/{vaultName}/notification-configuration', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'DescribeJob' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/jobs/{jobId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GlacierJobDescription', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'jobId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'DescribeVault' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DescribeVaultOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'GetJobOutput' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/jobs/{jobId}/output', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetJobOutputOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'jobId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'range' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Range', ), 'saveAs' => array( 'location' => 'response_body', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'GetVaultNotifications' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/notification-configuration', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetVaultNotificationsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'InitiateJob' => array( 'httpMethod' => 'POST', 'uri' => '/{accountId}/vaults/{vaultName}/jobs', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'InitiateJobOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Format' => array( 'type' => 'string', 'location' => 'json', ), 'Type' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveId' => array( 'type' => 'string', 'location' => 'json', ), 'Description' => array( 'type' => 'string', 'location' => 'json', ), 'SNSTopic' => array( 'type' => 'string', 'location' => 'json', ), 'RetrievalByteRange' => array( 'type' => 'string', 'location' => 'json', ), 'InventoryRetrievalParameters' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'StartDate' => array( 'type' => 'string', ), 'EndDate' => array( 'type' => 'string', ), 'Limit' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'InitiateMultipartUpload' => array( 'httpMethod' => 'POST', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'InitiateMultipartUploadOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'archiveDescription' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-description', ), 'partSize' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-part-size', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'ListJobs' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/jobs', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListJobsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'limit' => array( 'type' => 'string', 'location' => 'query', ), 'marker' => array( 'type' => 'string', 'location' => 'query', ), 'statuscode' => array( 'type' => 'string', 'location' => 'query', ), 'completed' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'ListMultipartUploads' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListMultipartUploadsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'limit' => array( 'type' => 'string', 'location' => 'query', ), 'marker' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'ListParts' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListPartsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'uploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'marker' => array( 'type' => 'string', 'location' => 'query', ), 'limit' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'ListVaults' => array( 'httpMethod' => 'GET', 'uri' => '/{accountId}/vaults', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListVaultsOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'marker' => array( 'type' => 'string', 'location' => 'query', ), 'limit' => array( 'type' => 'string', 'location' => 'query', ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'SetVaultNotifications' => array( 'httpMethod' => 'PUT', 'uri' => '/{accountId}/vaults/{vaultName}/notification-configuration', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'SNSTopic' => array( 'type' => 'string', 'location' => 'json', ), 'Events' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'string', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'UploadArchive' => array( 'httpMethod' => 'POST', 'uri' => '/{accountId}/vaults/{vaultName}/archives', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ArchiveCreationOutput', 'responseType' => 'model', 'parameters' => array( 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'archiveDescription' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-description', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), 'body' => array( 'type' => array( 'string', 'object', ), 'location' => 'body', ), 'ContentSHA256' => array( 'default' => true, ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if, when uploading an archive, Amazon Glacier times out while receiving the upload.', 'class' => 'RequestTimeoutException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), 'UploadMultipartPart' => array( 'httpMethod' => 'PUT', 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'UploadMultipartPartOutput', 'responseType' => 'model', 'parameters' => array( 'accountId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'vaultName' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'uploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), 'range' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Range', ), 'body' => array( 'type' => array( 'string', 'object', ), 'location' => 'body', ), 'ContentSHA256' => array( 'default' => true, ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', 'class' => 'ResourceNotFoundException', ), array( 'reason' => 'Returned if a parameter of the request is incorrectly specified.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'Returned if a required header or parameter is missing from the request.', 'class' => 'MissingParameterValueException', ), array( 'reason' => 'Returned if, when uploading an archive, Amazon Glacier times out while receiving the upload.', 'class' => 'RequestTimeoutException', ), array( 'reason' => 'Returned if the service cannot complete the request.', 'class' => 'ServiceUnavailableException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ArchiveCreationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'location' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Location', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), 'archiveId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-id', ), ), ), 'CreateVaultOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'location' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Location', ), ), ), 'GlacierJobDescription' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobId' => array( 'type' => 'string', 'location' => 'json', ), 'JobDescription' => array( 'type' => 'string', 'location' => 'json', ), 'Action' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveId' => array( 'type' => 'string', 'location' => 'json', ), 'VaultARN' => array( 'type' => 'string', 'location' => 'json', ), 'CreationDate' => array( 'type' => 'string', 'location' => 'json', ), 'Completed' => array( 'type' => 'boolean', 'location' => 'json', ), 'StatusCode' => array( 'type' => 'string', 'location' => 'json', ), 'StatusMessage' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveSizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'InventorySizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'SNSTopic' => array( 'type' => 'string', 'location' => 'json', ), 'CompletionDate' => array( 'type' => 'string', 'location' => 'json', ), 'SHA256TreeHash' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveSHA256TreeHash' => array( 'type' => 'string', 'location' => 'json', ), 'RetrievalByteRange' => array( 'type' => 'string', 'location' => 'json', ), 'InventoryRetrievalParameters' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'StartDate' => array( 'type' => 'string', ), 'EndDate' => array( 'type' => 'string', ), 'Limit' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), ), ), ), ), 'DescribeVaultOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VaultARN' => array( 'type' => 'string', 'location' => 'json', ), 'VaultName' => array( 'type' => 'string', 'location' => 'json', ), 'CreationDate' => array( 'type' => 'string', 'location' => 'json', ), 'LastInventoryDate' => array( 'type' => 'string', 'location' => 'json', ), 'NumberOfArchives' => array( 'type' => 'numeric', 'location' => 'json', ), 'SizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'GetJobOutputOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'body' => array( 'type' => 'string', 'instanceOf' => 'Guzzle\\Http\\EntityBody', 'location' => 'body', ), 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), 'status' => array( 'type' => 'numeric', 'location' => 'statusCode', ), 'contentRange' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Range', ), 'acceptRanges' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Accept-Ranges', ), 'contentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'archiveDescription' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-archive-description', ), ), ), 'GetVaultNotificationsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SNSTopic' => array( 'type' => 'string', 'location' => 'json', ), 'Events' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'string', 'type' => 'string', ), ), ), ), 'InitiateJobOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'location' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Location', ), 'jobId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-job-id', ), ), ), 'InitiateMultipartUploadOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'location' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Location', ), 'uploadId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-multipart-upload-id', ), ), ), 'ListJobsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'GlacierJobDescription', 'type' => 'object', 'properties' => array( 'JobId' => array( 'type' => 'string', ), 'JobDescription' => array( 'type' => 'string', ), 'Action' => array( 'type' => 'string', ), 'ArchiveId' => array( 'type' => 'string', ), 'VaultARN' => array( 'type' => 'string', ), 'CreationDate' => array( 'type' => 'string', ), 'Completed' => array( 'type' => 'boolean', ), 'StatusCode' => array( 'type' => 'string', ), 'StatusMessage' => array( 'type' => 'string', ), 'ArchiveSizeInBytes' => array( 'type' => 'numeric', ), 'InventorySizeInBytes' => array( 'type' => 'numeric', ), 'SNSTopic' => array( 'type' => 'string', ), 'CompletionDate' => array( 'type' => 'string', ), 'SHA256TreeHash' => array( 'type' => 'string', ), 'ArchiveSHA256TreeHash' => array( 'type' => 'string', ), 'RetrievalByteRange' => array( 'type' => 'string', ), 'InventoryRetrievalParameters' => array( 'type' => 'object', 'properties' => array( 'Format' => array( 'type' => 'string', ), 'StartDate' => array( 'type' => 'string', ), 'EndDate' => array( 'type' => 'string', ), 'Limit' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListMultipartUploadsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UploadsList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'UploadListElement', 'type' => 'object', 'properties' => array( 'MultipartUploadId' => array( 'type' => 'string', ), 'VaultARN' => array( 'type' => 'string', ), 'ArchiveDescription' => array( 'type' => 'string', ), 'PartSizeInBytes' => array( 'type' => 'numeric', ), 'CreationDate' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListPartsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MultipartUploadId' => array( 'type' => 'string', 'location' => 'json', ), 'VaultARN' => array( 'type' => 'string', 'location' => 'json', ), 'ArchiveDescription' => array( 'type' => 'string', 'location' => 'json', ), 'PartSizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'CreationDate' => array( 'type' => 'string', 'location' => 'json', ), 'Parts' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'PartListElement', 'type' => 'object', 'properties' => array( 'RangeInBytes' => array( 'type' => 'string', ), 'SHA256TreeHash' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListVaultsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VaultList' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DescribeVaultOutput', 'type' => 'object', 'properties' => array( 'VaultARN' => array( 'type' => 'string', ), 'VaultName' => array( 'type' => 'string', ), 'CreationDate' => array( 'type' => 'string', ), 'LastInventoryDate' => array( 'type' => 'string', ), 'NumberOfArchives' => array( 'type' => 'numeric', ), 'SizeInBytes' => array( 'type' => 'numeric', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UploadMultipartPartOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'checksum' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-sha256-tree-hash', ), ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 3, 'max_attempts' => 15, ), '__VaultState' => array( 'operation' => 'DescribeVault', ), 'VaultExists' => array( 'extends' => '__VaultState', 'success.type' => 'output', 'ignore_errors' => array( 'ResourceNotFoundException', ), ), 'VaultNotExists' => array( 'extends' => '__VaultState', 'success.type' => 'error', 'success.value' => 'ResourceNotFoundException', ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/iam-%s.php' )) ->build(); } } '2010-05-08', 'endpointPrefix' => 'iam', 'serviceFullName' => 'AWS Identity and Access Management', 'serviceAbbreviation' => 'IAM', 'serviceType' => 'query', 'globalEndpoint' => 'iam.amazonaws.com', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Iam', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'iam.us-gov.amazonaws.com', ), ), 'operations' => array( 'AddRoleToInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddRoleToInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'AddUserToGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddUserToGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'ChangePassword' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ChangePassword', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'OldPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'NewPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the type of user for the transaction was incorrect.', 'class' => 'InvalidUserTypeException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), ), ), 'CreateAccessKey' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateAccessKeyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateAccessKey', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateAccountAlias' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateAccountAlias', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'AccountAlias' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 63, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateGroupResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'CreateInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateInstanceProfileResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateLoginProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateLoginProfileResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateLoginProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'Password' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the provided password did not meet the requirements imposed by the account password policy.', 'class' => 'PasswordPolicyViolationException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'AssumeRolePolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), ), ), 'CreateSAMLProvider' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateSAMLProviderResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateSAMLProvider', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SAMLMetadataDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1000, 'maxLength' => 10000000, ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'InvalidInputException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'CreateUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateUserResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'CreateVirtualMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateVirtualMFADeviceResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateVirtualMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'VirtualMFADeviceName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), ), ), 'DeactivateMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeactivateMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'SerialNumber' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteAccessKey' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAccessKey', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'AccessKeyId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 16, 'maxLength' => 32, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteAccountAlias' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAccountAlias', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'AccountAlias' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 3, 'maxLength' => 63, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteAccountPasswordPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAccountPasswordPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'DeleteGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteGroupPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteGroupPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteLoginProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteLoginProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteRolePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteRolePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteSAMLProvider' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSAMLProvider', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SAMLProviderArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'class' => 'InvalidInputException', ), ), ), 'DeleteServerCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteServerCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'ServerCertificateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteSigningCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteSigningCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'CertificateId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 24, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), ), ), 'DeleteUserPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteUserPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'DeleteVirtualMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVirtualMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SerialNumber' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', 'class' => 'DeleteConflictException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'EnableMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'SerialNumber' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), 'AuthenticationCode1' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), 'AuthenticationCode2' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), array( 'reason' => 'The request was rejected because the authentication code was not recognized. The error message describes the specific error.', 'class' => 'InvalidAuthenticationCodeException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetAccountPasswordPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetAccountPasswordPolicyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetAccountPasswordPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetAccountSummary' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetAccountSummaryResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetAccountSummary', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), ), ), 'GetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetGroupResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetGroupPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetGroupPolicyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetGroupPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetInstanceProfileResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetLoginProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetLoginProfileResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetLoginProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetRolePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetRolePolicyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetRolePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetSAMLProvider' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSAMLProviderResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSAMLProvider', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SAMLProviderArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'class' => 'InvalidInputException', ), ), ), 'GetServerCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetServerCertificateResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetServerCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'ServerCertificateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetUserResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'GetUserPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetUserPolicyResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetUserPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListAccessKeys' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListAccessKeysResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListAccessKeys', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListAccountAliases' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListAccountAliasesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListAccountAliases', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListGroupPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListGroupPoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListGroupPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListGroupsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListGroupsForUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListGroupsForUserResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListGroupsForUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListInstanceProfiles' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListInstanceProfilesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListInstanceProfiles', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListInstanceProfilesForRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListInstanceProfilesForRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListInstanceProfilesForRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListMFADevices' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListMFADevicesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListMFADevices', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListRolePolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListRolePoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListRolePolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListRoles' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListRolesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListRoles', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListSAMLProviders' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListSAMLProvidersResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListSAMLProviders', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), ), ), 'ListServerCertificates' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListServerCertificatesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListServerCertificates', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListSigningCertificates' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListSigningCertificatesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListSigningCertificates', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListUserPolicies' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListUserPoliciesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListUserPolicies', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'ListUsers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListUsersResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListUsers', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'PathPrefix' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'ListVirtualMFADevices' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListVirtualMFADevicesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListVirtualMFADevices', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'AssignmentStatus' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 320, ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 1, 'maximum' => 1000, ), ), ), 'PutGroupPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutGroupPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'PutRolePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutRolePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'PutUserPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutUserPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'PolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), 'RemoveRoleFromInstanceProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemoveRoleFromInstanceProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'InstanceProfileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'RemoveUserFromGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemoveUserFromGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'ResyncMFADevice' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResyncMFADevice', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'SerialNumber' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), 'AuthenticationCode1' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), 'AuthenticationCode2' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the authentication code was not recognized. The error message describes the specific error.', 'class' => 'InvalidAuthenticationCodeException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateAccessKey' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateAccessKey', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'AccessKeyId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 16, 'maxLength' => 32, ), 'Status' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateAccountPasswordPolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateAccountPasswordPolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'MinimumPasswordLength' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 6, 'maximum' => 128, ), 'RequireSymbols' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RequireNumbers' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RequireUppercaseCharacters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'RequireLowercaseCharacters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AllowUsersToChangePassword' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateAssumeRolePolicy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateAssumeRolePolicy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'RoleName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'PolicyDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 131072, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'GroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'NewPath' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'NewGroupName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateLoginProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateLoginProfile', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), 'Password' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because the provided password did not meet the requirements imposed by the account password policy.', 'class' => 'PasswordPolicyViolationException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateSAMLProvider' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateSAMLProviderResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateSAMLProvider', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'SAMLMetadataDocument' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1000, 'maxLength' => 10000000, ), 'SAMLProviderArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'class' => 'InvalidInputException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateServerCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateServerCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'ServerCertificateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'NewPath' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'NewServerCertificateName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateSigningCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateSigningCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'CertificateId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 24, 'maxLength' => 128, ), 'Status' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), ), ), 'UpdateUser' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateUser', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'NewPath' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'NewUserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', 'class' => 'EntityTemporarilyUnmodifiableException', ), ), ), 'UploadServerCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UploadServerCertificateResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UploadServerCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'Path' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 512, ), 'ServerCertificateName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'CertificateBody' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'PrivateKey' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), 'CertificateChain' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2097152, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because the certificate was malformed or expired. The error message describes the specific error.', 'class' => 'MalformedCertificateException', ), array( 'reason' => 'The request was rejected because the public key certificate and the private key do not match.', 'class' => 'KeyPairMismatchException', ), ), ), 'UploadSigningCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UploadSigningCertificateResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UploadSigningCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-05-08', ), 'UserName' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 128, ), 'CertificateBody' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 16384, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', 'class' => 'LimitExceededException', ), array( 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', 'class' => 'EntityAlreadyExistsException', ), array( 'reason' => 'The request was rejected because the certificate was malformed or expired. The error message describes the specific error.', 'class' => 'MalformedCertificateException', ), array( 'reason' => 'The request was rejected because the certificate is invalid.', 'class' => 'InvalidCertificateException', ), array( 'reason' => 'The request was rejected because the same certificate is associated to another user under the account.', 'class' => 'DuplicateCertificateException', ), array( 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', 'class' => 'NoSuchEntityException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CreateAccessKeyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccessKey' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'AccessKeyId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'CreateGroupResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Group' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'CreateInstanceProfileResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceProfile' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'InstanceProfileName' => array( 'type' => 'string', ), 'InstanceProfileId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'Roles' => array( 'type' => 'array', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'CreateLoginProfileResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoginProfile' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'CreateRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Role' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), 'CreateSAMLProviderResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SAMLProviderArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'CreateUserResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'User' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'CreateVirtualMFADeviceResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VirtualMFADevice' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'SerialNumber' => array( 'type' => 'string', ), 'Base32StringSeed' => array( 'type' => 'string', ), 'QRCodePNG' => array( 'type' => 'string', ), 'User' => array( 'type' => 'object', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), 'EnableDate' => array( 'type' => 'string', ), ), ), ), ), 'GetAccountPasswordPolicyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PasswordPolicy' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'MinimumPasswordLength' => array( 'type' => 'numeric', ), 'RequireSymbols' => array( 'type' => 'boolean', ), 'RequireNumbers' => array( 'type' => 'boolean', ), 'RequireUppercaseCharacters' => array( 'type' => 'boolean', ), 'RequireLowercaseCharacters' => array( 'type' => 'boolean', ), 'AllowUsersToChangePassword' => array( 'type' => 'boolean', ), 'ExpirePasswords' => array( 'type' => 'boolean', ), 'MaxPasswordAge' => array( 'type' => 'numeric', ), ), ), ), ), 'GetAccountSummaryResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SummaryMap' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlMap' => array( 'Users', 'UsersQuota', 'Groups', 'GroupsQuota', 'ServerCertificates', 'ServerCertificatesQuota', 'UserPolicySizeQuota', 'GroupPolicySizeQuota', 'GroupsPerUserQuota', 'SigningCertificatesPerUserQuota', 'AccessKeysPerUserQuota', 'MFADevices', 'MFADevicesInUse', 'AccountMFAEnabled', ), ), 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'numeric', ), ), ), 'additionalProperties' => false, ), ), ), 'GetGroupResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Group' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), 'Users' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'User', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetGroupPolicyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GroupName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyDocument' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetInstanceProfileResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceProfile' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'InstanceProfileName' => array( 'type' => 'string', ), 'InstanceProfileId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'Roles' => array( 'type' => 'array', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'GetLoginProfileResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoginProfile' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'GetRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Role' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), 'GetRolePolicyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RoleName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyDocument' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetSAMLProviderResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SAMLMetadataDocument' => array( 'type' => 'string', 'location' => 'xml', ), 'CreateDate' => array( 'type' => 'string', 'location' => 'xml', ), 'ValidUntil' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetServerCertificateResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ServerCertificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'ServerCertificateMetadata' => array( 'type' => 'object', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'ServerCertificateName' => array( 'type' => 'string', ), 'ServerCertificateId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), 'CertificateBody' => array( 'type' => 'string', ), 'CertificateChain' => array( 'type' => 'string', ), ), ), ), ), 'GetUserResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'User' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), 'GetUserPolicyResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UserName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyName' => array( 'type' => 'string', 'location' => 'xml', ), 'PolicyDocument' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListAccessKeysResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccessKeyMetadata' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'AccessKeyMetadata', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'AccessKeyId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListAccountAliasesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AccountAliases' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'accountAliasType', 'type' => 'string', 'sentAs' => 'member', ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListGroupPoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyNames' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'policyNameType', 'type' => 'string', 'sentAs' => 'member', ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListGroupsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Groups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Group', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListGroupsForUserResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Groups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Group', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'GroupName' => array( 'type' => 'string', ), 'GroupId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListInstanceProfilesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceProfiles' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InstanceProfile', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'InstanceProfileName' => array( 'type' => 'string', ), 'InstanceProfileId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'Roles' => array( 'type' => 'array', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListInstanceProfilesForRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceProfiles' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'InstanceProfile', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'InstanceProfileName' => array( 'type' => 'string', ), 'InstanceProfileId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'Roles' => array( 'type' => 'array', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListMFADevicesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MFADevices' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'MFADevice', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'SerialNumber' => array( 'type' => 'string', ), 'EnableDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListRolePoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyNames' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'policyNameType', 'type' => 'string', 'sentAs' => 'member', ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListRolesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Roles' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Role', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'RoleName' => array( 'type' => 'string', ), 'RoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), 'AssumeRolePolicyDocument' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListSAMLProvidersResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SAMLProviderList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SAMLProviderListEntry', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Arn' => array( 'type' => 'string', ), 'ValidUntil' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), ), ), 'ListServerCertificatesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ServerCertificateMetadataList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ServerCertificateMetadata', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'ServerCertificateName' => array( 'type' => 'string', ), 'ServerCertificateId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListSigningCertificatesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Certificates' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SigningCertificate', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'CertificateId' => array( 'type' => 'string', ), 'CertificateBody' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListUserPoliciesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PolicyNames' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'policyNameType', 'type' => 'string', 'sentAs' => 'member', ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListUsersResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Users' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'User', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListVirtualMFADevicesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VirtualMFADevices' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'VirtualMFADevice', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SerialNumber' => array( 'type' => 'string', ), 'Base32StringSeed' => array( 'type' => 'string', ), 'QRCodePNG' => array( 'type' => 'string', ), 'User' => array( 'type' => 'object', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'UserName' => array( 'type' => 'string', ), 'UserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'CreateDate' => array( 'type' => 'string', ), ), ), 'EnableDate' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'UpdateSAMLProviderResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SAMLProviderArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'UploadServerCertificateResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ServerCertificateMetadata' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Path' => array( 'type' => 'string', ), 'ServerCertificateName' => array( 'type' => 'string', ), 'ServerCertificateId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), ), ), 'UploadSigningCertificateResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Certificate' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'UserName' => array( 'type' => 'string', ), 'CertificateId' => array( 'type' => 'string', ), 'CertificateBody' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'UploadDate' => array( 'type' => 'string', ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'GetGroup' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Users', ), 'ListAccessKeys' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'AccessKeyMetadata', ), 'ListAccountAliases' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'AccountAliases', ), 'ListGroupPolicies' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'PolicyNames', ), 'ListGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Groups', ), 'ListGroupsForUser' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Groups', ), 'ListInstanceProfiles' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'InstanceProfiles', ), 'ListInstanceProfilesForRole' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'InstanceProfiles', ), 'ListMFADevices' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'MFADevices', ), 'ListRolePolicies' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'PolicyNames', ), 'ListRoles' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Roles', ), 'ListSAMLProviders' => array( 'result_key' => 'SAMLProviderList', ), 'ListServerCertificates' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'ServerCertificateMetadataList', ), 'ListSigningCertificates' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Certificates', ), 'ListUserPolicies' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'PolicyNames', ), 'ListUsers' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'Users', ), 'ListVirtualMFADevices' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'VirtualMFADevices', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/importexport-%s.php' )) ->build(); // If the Symfony YAML component is installed, add a listener that will convert arrays to proper YAML in when // specifying the "Manifest" parameter of the "CreateJob" operation if (class_exists('Symfony\Component\Yaml\Yaml')) { $client->addSubscriber(new JobManifestListener()); } return $client; } } nextToken = null; if ($result->get($this->get('more_key'))) { $jobs = $result->get($this->get('result_key')) ?: array(); $numJobs = count($jobs); $this->nextToken = $numJobs ? $jobs[$numJobs - 1]['JobId'] : null; } } } array('onCommandBeforePrepare')); } /** * An event handler for assisting with formatting the Manifest parameter of CreateJob operation into YAML * * @param Event $event The event being handled */ public function onCommandBeforePrepare(Event $event) { /** @var $command \Guzzle\Service\Command\AbstractCommand */ $command = $event['command']; if ($command->getName() === 'CreateJob') { $manifest = $command->get('Manifest'); if (!is_string($manifest) && class_exists('Symfony\Component\Yaml\Yaml')) { $command->set('Manifest', \Symfony\Component\Yaml\Yaml::dump($manifest)); } } } } '2010-06-01', 'endpointPrefix' => 'importexport', 'serviceFullName' => 'AWS Import/Export', 'serviceType' => 'query', 'globalEndpoint' => 'importexport.amazonaws.com', 'resultWrapped' => true, 'signatureVersion' => 'v2', 'namespace' => 'ImportExport', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'importexport.amazonaws.com', ), ), 'operations' => array( 'CancelJob' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CancelJobOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CancelJob', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'JobId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', 'class' => 'InvalidJobIdException', ), array( 'reason' => 'Indicates that the specified job has expired out of the system.', 'class' => 'ExpiredJobIdException', ), array( 'reason' => 'The specified job ID has been canceled and is no longer valid.', 'class' => 'CanceledJobIdException', ), array( 'reason' => 'AWS Import/Export cannot cancel the job', 'class' => 'UnableToCancelJobIdException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), ), ), 'CreateJob' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateJobOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateJob', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'JobType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Manifest' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ManifestAddendum' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ValidateOnly' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameters was missing from the request.', 'class' => 'MissingParameterException', ), array( 'reason' => 'One or more parameters had an invalid value.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'One or more parameters had an invalid value.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), array( 'reason' => 'The address specified in the manifest is invalid.', 'class' => 'InvalidAddressException', ), array( 'reason' => 'One or more manifest fields was invalid. Please correct and resubmit.', 'class' => 'InvalidManifestFieldException', ), array( 'reason' => 'One or more required fields were missing from the manifest file. Please correct and resubmit.', 'class' => 'MissingManifestFieldException', ), array( 'reason' => 'The specified bucket does not exist. Create the specified bucket or change the manifest\'s bucket, exportBucket, or logBucket field to a bucket that the account, as specified by the manifest\'s Access Key ID, has write permissions to.', 'class' => 'NoSuchBucketException', ), array( 'reason' => 'One or more required customs parameters was missing from the manifest.', 'class' => 'MissingCustomsException', ), array( 'reason' => 'One or more customs parameters was invalid. Please correct and resubmit.', 'class' => 'InvalidCustomsException', ), array( 'reason' => 'File system specified in export manifest is invalid.', 'class' => 'InvalidFileSystemException', ), array( 'reason' => 'Your manifest file contained buckets from multiple regions. A job is restricted to buckets from one region. Please correct and resubmit.', 'class' => 'MultipleRegionsException', ), array( 'reason' => 'The account specified does not have the appropriate bucket permissions.', 'class' => 'BucketPermissionException', ), array( 'reason' => 'Your manifest is not well-formed.', 'class' => 'MalformedManifestException', ), ), ), 'GetStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetStatusOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'JobId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', 'class' => 'InvalidJobIdException', ), array( 'reason' => 'Indicates that the specified job has expired out of the system.', 'class' => 'ExpiredJobIdException', ), array( 'reason' => 'The specified job ID has been canceled and is no longer valid.', 'class' => 'CanceledJobIdException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), ), ), 'ListJobs' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListJobsOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListJobs', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'MaxJobs' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more parameters had an invalid value.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), ), ), 'UpdateJob' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'UpdateJobOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'UpdateJob', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-06-01', ), 'JobId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Manifest' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'JobType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ValidateOnly' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'One or more required parameters was missing from the request.', 'class' => 'MissingParameterException', ), array( 'reason' => 'One or more parameters had an invalid value.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', 'class' => 'InvalidAccessKeyIdException', ), array( 'reason' => 'The address specified in the manifest is invalid.', 'class' => 'InvalidAddressException', ), array( 'reason' => 'One or more manifest fields was invalid. Please correct and resubmit.', 'class' => 'InvalidManifestFieldException', ), array( 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', 'class' => 'InvalidJobIdException', ), array( 'reason' => 'One or more required fields were missing from the manifest file. Please correct and resubmit.', 'class' => 'MissingManifestFieldException', ), array( 'reason' => 'The specified bucket does not exist. Create the specified bucket or change the manifest\'s bucket, exportBucket, or logBucket field to a bucket that the account, as specified by the manifest\'s Access Key ID, has write permissions to.', 'class' => 'NoSuchBucketException', ), array( 'reason' => 'Indicates that the specified job has expired out of the system.', 'class' => 'ExpiredJobIdException', ), array( 'reason' => 'The specified job ID has been canceled and is no longer valid.', 'class' => 'CanceledJobIdException', ), array( 'reason' => 'One or more required customs parameters was missing from the manifest.', 'class' => 'MissingCustomsException', ), array( 'reason' => 'One or more customs parameters was invalid. Please correct and resubmit.', 'class' => 'InvalidCustomsException', ), array( 'reason' => 'File system specified in export manifest is invalid.', 'class' => 'InvalidFileSystemException', ), array( 'reason' => 'Your manifest file contained buckets from multiple regions. A job is restricted to buckets from one region. Please correct and resubmit.', 'class' => 'MultipleRegionsException', ), array( 'reason' => 'The account specified does not have the appropriate bucket permissions.', 'class' => 'BucketPermissionException', ), array( 'reason' => 'Your manifest is not well-formed.', 'class' => 'MalformedManifestException', ), ), ), ), 'models' => array( 'CancelJobOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Success' => array( 'type' => 'boolean', 'location' => 'xml', ), ), ), 'CreateJobOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobId' => array( 'type' => 'string', 'location' => 'xml', ), 'JobType' => array( 'type' => 'string', 'location' => 'xml', ), 'AwsShippingAddress' => array( 'type' => 'string', 'location' => 'xml', ), 'Signature' => array( 'type' => 'string', 'location' => 'xml', ), 'SignatureFileContents' => array( 'type' => 'string', 'location' => 'xml', ), 'WarningMessage' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetStatusOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'JobId' => array( 'type' => 'string', 'location' => 'xml', ), 'JobType' => array( 'type' => 'string', 'location' => 'xml', ), 'AwsShippingAddress' => array( 'type' => 'string', 'location' => 'xml', ), 'LocationCode' => array( 'type' => 'string', 'location' => 'xml', ), 'LocationMessage' => array( 'type' => 'string', 'location' => 'xml', ), 'ProgressCode' => array( 'type' => 'string', 'location' => 'xml', ), 'ProgressMessage' => array( 'type' => 'string', 'location' => 'xml', ), 'Carrier' => array( 'type' => 'string', 'location' => 'xml', ), 'TrackingNumber' => array( 'type' => 'string', 'location' => 'xml', ), 'LogBucket' => array( 'type' => 'string', 'location' => 'xml', ), 'LogKey' => array( 'type' => 'string', 'location' => 'xml', ), 'ErrorCount' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Signature' => array( 'type' => 'string', 'location' => 'xml', ), 'SignatureFileContents' => array( 'type' => 'string', 'location' => 'xml', ), 'CurrentManifest' => array( 'type' => 'string', 'location' => 'xml', ), 'CreationDate' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListJobsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Jobs' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Job', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'JobId' => array( 'type' => 'string', ), 'CreationDate' => array( 'type' => 'string', ), 'IsCanceled' => array( 'type' => 'boolean', ), 'JobType' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), ), ), 'UpdateJobOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Success' => array( 'type' => 'boolean', 'location' => 'xml', ), 'WarningMessage' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'ListJobs' => array( 'token_param' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxJobs', 'result_key' => 'Jobs', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/kinesis-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser) ->build(); } public function __call($method, $args) { // Overrides the parent behavior to make sure that the GetShardIterator operation works correctly if ($method === 'getShardIterator') { $params = isset($args[0]) ? $args[0] : array(); return $this->getCommand($method, $params)->getResult(); } else { return parent::__call($method, $args); } } } '2013-12-02', 'endpointPrefix' => 'kinesis', 'serviceFullName' => 'Amazon Kinesis', 'serviceAbbreviation' => 'Kinesis', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'Kinesis_20131202.', 'signatureVersion' => 'v4', 'namespace' => 'Kinesis', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'kinesis.us-east-1.amazonaws.com', ), ), 'operations' => array( 'CreateStream' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.CreateStream', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardCount' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'class' => 'ResourceInUseException', ), array( 'class' => 'LimitExceededException', ), array( 'class' => 'InvalidArgumentException', ), ), ), 'DeleteStream' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.DeleteStream', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'LimitExceededException', ), ), ), 'DescribeStream' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStreamOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.DescribeStream', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 10000, ), 'ExclusiveStartShardId' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'LimitExceededException', ), ), ), 'GetRecords' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetRecordsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.GetRecords', ), 'ShardIterator' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 512, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 10000, ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'ProvisionedThroughputExceededException', ), array( 'class' => 'ExpiredIteratorException', ), ), ), 'GetShardIterator' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetShardIteratorOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.GetShardIterator', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardIteratorType' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'StartingSequenceNumber' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'ProvisionedThroughputExceededException', ), ), ), 'ListStreams' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListStreamsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.ListStreams', ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 10000, ), 'ExclusiveStartStreamName' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'LimitExceededException', ), ), ), 'MergeShards' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.MergeShards', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardToMerge' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'AdjacentShardToMerge' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'ResourceInUseException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'LimitExceededException', ), ), ), 'PutRecord' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PutRecordOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.PutRecord', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'Data' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'filters' => array( 'base64_encode', ), ), 'PartitionKey' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'ExplicitHashKey' => array( 'type' => 'string', 'location' => 'json', ), 'SequenceNumberForOrdering' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'ProvisionedThroughputExceededException', ), ), ), 'SplitShard' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'Kinesis_20131202.SplitShard', ), 'StreamName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'ShardToSplit' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 128, ), 'NewStartingHashKey' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'class' => 'ResourceNotFoundException', ), array( 'class' => 'ResourceInUseException', ), array( 'class' => 'InvalidArgumentException', ), array( 'class' => 'LimitExceededException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DescribeStreamOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StreamDescription' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'StreamName' => array( 'type' => 'string', ), 'StreamARN' => array( 'type' => 'string', ), 'StreamStatus' => array( 'type' => 'string', ), 'Shards' => array( 'type' => 'array', 'items' => array( 'name' => 'Shard', 'type' => 'object', 'properties' => array( 'ShardId' => array( 'type' => 'string', ), 'ParentShardId' => array( 'type' => 'string', ), 'AdjacentParentShardId' => array( 'type' => 'string', ), 'HashKeyRange' => array( 'type' => 'object', 'properties' => array( 'StartingHashKey' => array( 'type' => 'string', ), 'EndingHashKey' => array( 'type' => 'string', ), ), ), 'SequenceNumberRange' => array( 'type' => 'object', 'properties' => array( 'StartingSequenceNumber' => array( 'type' => 'string', ), 'EndingSequenceNumber' => array( 'type' => 'string', ), ), ), ), ), ), 'HasMoreShards' => array( 'type' => 'boolean', ), ), ), ), ), 'GetRecordsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Records' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Record', 'type' => 'object', 'properties' => array( 'SequenceNumber' => array( 'type' => 'string', ), 'Data' => array( 'type' => 'string', 'filters' => array( 'base64_decode', ), ), 'PartitionKey' => array( 'type' => 'string', ), ), ), ), 'NextShardIterator' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'GetShardIteratorOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ShardIterator' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListStreamsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StreamNames' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StreamName', 'type' => 'string', ), ), 'HasMoreStreams' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'PutRecordOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ShardId' => array( 'type' => 'string', 'location' => 'json', ), 'SequenceNumber' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), ); # Apache License Version 2.0, January 2004 TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION ## 1. Definitions. "License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document. "Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License. "Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity. "You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License. "Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files. "Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types. "Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below). "Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof. "Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution." "Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work. ## 2. Grant of Copyright License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form. ## 3. Grant of Patent License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed. ## 4. Redistribution. You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions: 1. You must give any other recipients of the Work or Derivative Works a copy of this License; and 2. You must cause any modified files to carry prominent notices stating that You changed the files; and 3. You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and 4. If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License. You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License. ## 5. Submission of Contributions. Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions. ## 6. Trademarks. This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file. ## 7. Disclaimer of Warranty. Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License. ## 8. Limitation of Liability. In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages. ## 9. Accepting Warranty or Additional Liability. While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability. END OF TERMS AND CONDITIONS # AWS SDK for PHP Copyright 2010-2013 Amazon.com, Inc. or its affiliates. All Rights Reserved. Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with the License. A copy of the License is located at or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. # Guzzle Copyright (c) 2011 Michael Dowling, https://github.com/mtdowling Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. # Symfony Copyright (c) 2004-2012 Fabien Potencier Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. # Doctrine Common Copyright (c) 2006-2012 Doctrine Project Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. # Monolog Copyright (c) Jordi Boggiano Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/opsworks-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } '2013-02-18', 'endpointPrefix' => 'opsworks', 'serviceFullName' => 'AWS OpsWorks', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'OpsWorks_20130218.', 'signatureVersion' => 'v4', 'namespace' => 'OpsWorks', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'opsworks.us-east-1.amazonaws.com', ), ), 'operations' => array( 'AssignVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.AssignVolume', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'AssociateElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.AssociateElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'AttachElasticLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.AttachElasticLoadBalancer', ), 'ElasticLoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CloneStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CloneStackResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CloneStack', ), 'SourceStackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'Region' => array( 'type' => 'string', 'location' => 'json', ), 'VpcId' => array( 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'StackAttributesKeys', ), ), ), 'ServiceRoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'DefaultInstanceProfileArn' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultOs' => array( 'type' => 'string', 'location' => 'json', ), 'HostnameTheme' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultAvailabilityZone' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultSubnetId' => array( 'type' => 'string', 'location' => 'json', ), 'CustomJson' => array( 'type' => 'string', 'location' => 'json', ), 'ConfigurationManager' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'UseCustomCookbooks' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomCookbooksSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'DefaultSshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'ClonePermissions' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CloneAppIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'DefaultRootDeviceType' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateApp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateAppResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateApp', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Shortname' => array( 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Description' => array( 'type' => 'string', 'location' => 'json', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AppSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'Domains' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'EnableSsl' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'SslConfiguration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Certificate' => array( 'required' => true, 'type' => 'string', ), 'PrivateKey' => array( 'required' => true, 'type' => 'string', ), 'Chain' => array( 'type' => 'string', ), ), ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'AppAttributesKeys', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateDeployment' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateDeploymentResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateDeployment', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AppId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Command' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'Args' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'array', 'data' => array( 'shape_name' => 'String', ), 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), 'Comment' => array( 'type' => 'string', 'location' => 'json', ), 'CustomJson' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateInstanceResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateInstance', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'LayerIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'InstanceType' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AutoScalingType' => array( 'type' => 'string', 'location' => 'json', ), 'Hostname' => array( 'type' => 'string', 'location' => 'json', ), 'Os' => array( 'type' => 'string', 'location' => 'json', ), 'AmiId' => array( 'type' => 'string', 'location' => 'json', ), 'SshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'json', ), 'SubnetId' => array( 'type' => 'string', 'location' => 'json', ), 'Architecture' => array( 'type' => 'string', 'location' => 'json', ), 'RootDeviceType' => array( 'type' => 'string', 'location' => 'json', ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateLayer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateLayerResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateLayer', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Type' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Shortname' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'LayerAttributesKeys', ), ), ), 'CustomInstanceProfileArn' => array( 'type' => 'string', 'location' => 'json', ), 'CustomSecurityGroupIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Packages' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'VolumeConfigurations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeConfiguration', 'type' => 'object', 'properties' => array( 'MountPoint' => array( 'required' => true, 'type' => 'string', ), 'RaidLevel' => array( 'type' => 'numeric', ), 'NumberOfDisks' => array( 'required' => true, 'type' => 'numeric', ), 'Size' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), 'EnableAutoHealing' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AutoAssignElasticIps' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AutoAssignPublicIps' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomRecipes' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Setup' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Configure' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Deploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Undeploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Shutdown' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'CreateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateStackResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateStack', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Region' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'VpcId' => array( 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'StackAttributesKeys', ), ), ), 'ServiceRoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'DefaultInstanceProfileArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'DefaultOs' => array( 'type' => 'string', 'location' => 'json', ), 'HostnameTheme' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultAvailabilityZone' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultSubnetId' => array( 'type' => 'string', 'location' => 'json', ), 'CustomJson' => array( 'type' => 'string', 'location' => 'json', ), 'ConfigurationManager' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'UseCustomCookbooks' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomCookbooksSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'DefaultSshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultRootDeviceType' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), ), ), 'CreateUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateUserProfileResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.CreateUserProfile', ), 'IamUserArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'SshUsername' => array( 'type' => 'string', 'location' => 'json', ), 'SshPublicKey' => array( 'type' => 'string', 'location' => 'json', ), 'AllowSelfManagement' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), ), ), 'DeleteApp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteApp', ), 'AppId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'DeleteElasticIp' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'DeleteVolumes' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteLayer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteLayer', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteStack', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeleteUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeleteUserProfile', ), 'IamUserArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeregisterElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeregisterElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DeregisterVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DeregisterVolume', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeApps' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeAppsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeApps', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'AppIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeCommands' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCommandsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeCommands', ), 'DeploymentId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'CommandIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeDeployments' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeDeploymentsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeDeployments', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'AppId' => array( 'type' => 'string', 'location' => 'json', ), 'DeploymentIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeElasticIps' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeElasticIpsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeElasticIps', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'Ips' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeElasticLoadBalancers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeElasticLoadBalancersResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeElasticLoadBalancers', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'LayerIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeInstancesResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeInstances', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'LayerId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeLayers' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeLayersResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeLayers', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'LayerIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeLoadBasedAutoScaling' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeLoadBasedAutoScalingResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeLoadBasedAutoScaling', ), 'LayerIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeMyUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeMyUserProfileResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeMyUserProfile', ), ), ), 'DescribePermissions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribePermissionsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribePermissions', ), 'IamUserArn' => array( 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeRaidArrays' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeRaidArraysResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeRaidArrays', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'RaidArrayIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeServiceErrors' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeServiceErrorsResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeServiceErrors', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'ServiceErrorIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeStackSummary' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStackSummaryResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeStackSummary', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeStacks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStacksResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeStacks', ), 'StackIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeTimeBasedAutoScaling' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTimeBasedAutoScalingResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeTimeBasedAutoScaling', ), 'InstanceIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeUserProfiles' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeUserProfilesResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeUserProfiles', ), 'IamUserArns' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DescribeVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeVolumesResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DescribeVolumes', ), 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'type' => 'string', 'location' => 'json', ), 'RaidArrayId' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DetachElasticLoadBalancer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DetachElasticLoadBalancer', ), 'ElasticLoadBalancerName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'DisassociateElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.DisassociateElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'GetHostnameSuggestion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'GetHostnameSuggestionResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.GetHostnameSuggestion', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'RebootInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.RebootInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'RegisterElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RegisterElasticIpResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.RegisterElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'RegisterVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RegisterVolumeResult', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.RegisterVolume', ), 'Ec2VolumeId' => array( 'type' => 'string', 'location' => 'json', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'SetLoadBasedAutoScaling' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.SetLoadBasedAutoScaling', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Enable' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'UpScaling' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'InstanceCount' => array( 'type' => 'numeric', ), 'ThresholdsWaitTime' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 100, ), 'IgnoreMetricsTime' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 100, ), 'CpuThreshold' => array( 'type' => 'numeric', ), 'MemoryThreshold' => array( 'type' => 'numeric', ), 'LoadThreshold' => array( 'type' => 'numeric', ), ), ), 'DownScaling' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'InstanceCount' => array( 'type' => 'numeric', ), 'ThresholdsWaitTime' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 100, ), 'IgnoreMetricsTime' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 100, ), 'CpuThreshold' => array( 'type' => 'numeric', ), 'MemoryThreshold' => array( 'type' => 'numeric', ), 'LoadThreshold' => array( 'type' => 'numeric', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'SetPermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.SetPermission', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'IamUserArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AllowSsh' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AllowSudo' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'Level' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'SetTimeBasedAutoScaling' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.SetTimeBasedAutoScaling', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'AutoScalingSchedule' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Monday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Tuesday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Wednesday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Thursday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Friday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Saturday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), 'Sunday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'Hour', ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'StartInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.StartInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'StartStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.StartStack', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'StopInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.StopInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'StopStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.StopStack', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UnassignVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UnassignVolume', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateApp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateApp', ), 'AppId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'Description' => array( 'type' => 'string', 'location' => 'json', ), 'Type' => array( 'type' => 'string', 'location' => 'json', ), 'AppSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'Domains' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'EnableSsl' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'SslConfiguration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Certificate' => array( 'required' => true, 'type' => 'string', ), 'PrivateKey' => array( 'required' => true, 'type' => 'string', ), 'Chain' => array( 'type' => 'string', ), ), ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'AppAttributesKeys', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateElasticIp' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateElasticIp', ), 'ElasticIp' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateInstance', ), 'InstanceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'LayerIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'InstanceType' => array( 'type' => 'string', 'location' => 'json', ), 'AutoScalingType' => array( 'type' => 'string', 'location' => 'json', ), 'Hostname' => array( 'type' => 'string', 'location' => 'json', ), 'Os' => array( 'type' => 'string', 'location' => 'json', ), 'AmiId' => array( 'type' => 'string', 'location' => 'json', ), 'SshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'Architecture' => array( 'type' => 'string', 'location' => 'json', ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateLayer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateLayer', ), 'LayerId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'Shortname' => array( 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'LayerAttributesKeys', ), ), ), 'CustomInstanceProfileArn' => array( 'type' => 'string', 'location' => 'json', ), 'CustomSecurityGroupIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Packages' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'VolumeConfigurations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeConfiguration', 'type' => 'object', 'properties' => array( 'MountPoint' => array( 'required' => true, 'type' => 'string', ), 'RaidLevel' => array( 'type' => 'numeric', ), 'NumberOfDisks' => array( 'required' => true, 'type' => 'numeric', ), 'Size' => array( 'required' => true, 'type' => 'numeric', ), ), ), ), 'EnableAutoHealing' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AutoAssignElasticIps' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'AutoAssignPublicIps' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomRecipes' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Setup' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Configure' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Deploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Undeploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Shutdown' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateMyUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateMyUserProfile', ), 'SshPublicKey' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), ), ), 'UpdateStack' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateStack', ), 'StackId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'Attributes' => array( 'type' => 'object', 'location' => 'json', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'StackAttributesKeys', ), ), ), 'ServiceRoleArn' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultInstanceProfileArn' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultOs' => array( 'type' => 'string', 'location' => 'json', ), 'HostnameTheme' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultAvailabilityZone' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultSubnetId' => array( 'type' => 'string', 'location' => 'json', ), 'CustomJson' => array( 'type' => 'string', 'location' => 'json', ), 'ConfigurationManager' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'UseCustomCookbooks' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'CustomCookbooksSource' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'DefaultSshKeyName' => array( 'type' => 'string', 'location' => 'json', ), 'DefaultRootDeviceType' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateUserProfile' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateUserProfile', ), 'IamUserArn' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'SshUsername' => array( 'type' => 'string', 'location' => 'json', ), 'SshPublicKey' => array( 'type' => 'string', 'location' => 'json', ), 'AllowSelfManagement' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), 'UpdateVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'OpsWorks_20130218.UpdateVolume', ), 'VolumeId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'Name' => array( 'type' => 'string', 'location' => 'json', ), 'MountPoint' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request was invalid.', 'class' => 'ValidationException', ), array( 'reason' => 'Indicates that a resource was not found.', 'class' => 'ResourceNotFoundException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'CloneStackResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateAppResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AppId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateDeploymentResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DeploymentId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateInstanceResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'InstanceId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateLayerResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LayerId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateStackResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateUserProfileResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'IamUserArn' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeAppsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Apps' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'App', 'type' => 'object', 'properties' => array( 'AppId' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'Shortname' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'AppSource' => array( 'type' => 'object', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'Domains' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'EnableSsl' => array( 'type' => 'boolean', ), 'SslConfiguration' => array( 'type' => 'object', 'properties' => array( 'Certificate' => array( 'type' => 'string', ), 'PrivateKey' => array( 'type' => 'string', ), 'Chain' => array( 'type' => 'string', ), ), ), 'Attributes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'CreatedAt' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeCommandsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Commands' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Command', 'type' => 'object', 'properties' => array( 'CommandId' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), 'DeploymentId' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), 'AcknowledgedAt' => array( 'type' => 'string', ), 'CompletedAt' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'ExitCode' => array( 'type' => 'numeric', ), 'LogUrl' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeDeploymentsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Deployments' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Deployment', 'type' => 'object', 'properties' => array( 'DeploymentId' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'AppId' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), 'CompletedAt' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'IamUserArn' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), 'Command' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Args' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), 'Status' => array( 'type' => 'string', ), 'CustomJson' => array( 'type' => 'string', ), 'InstanceIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeElasticIpsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ElasticIps' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ElasticIp', 'type' => 'object', 'properties' => array( 'Ip' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Domain' => array( 'type' => 'string', ), 'Region' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeElasticLoadBalancersResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ElasticLoadBalancers' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ElasticLoadBalancer', 'type' => 'object', 'properties' => array( 'ElasticLoadBalancerName' => array( 'type' => 'string', ), 'Region' => array( 'type' => 'string', ), 'DnsName' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'LayerId' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'SubnetIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Ec2InstanceIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), ), ), 'DescribeInstancesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Instances' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Instance', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'Ec2InstanceId' => array( 'type' => 'string', ), 'Hostname' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'LayerIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'SecurityGroupIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'InstanceType' => array( 'type' => 'string', ), 'InstanceProfileArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Os' => array( 'type' => 'string', ), 'AmiId' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'SubnetId' => array( 'type' => 'string', ), 'PublicDns' => array( 'type' => 'string', ), 'PrivateDns' => array( 'type' => 'string', ), 'PublicIp' => array( 'type' => 'string', ), 'PrivateIp' => array( 'type' => 'string', ), 'ElasticIp' => array( 'type' => 'string', ), 'AutoScalingType' => array( 'type' => 'string', ), 'SshKeyName' => array( 'type' => 'string', ), 'SshHostRsaKeyFingerprint' => array( 'type' => 'string', ), 'SshHostDsaKeyFingerprint' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), 'LastServiceErrorId' => array( 'type' => 'string', ), 'Architecture' => array( 'type' => 'string', ), 'RootDeviceType' => array( 'type' => 'string', ), 'RootDeviceVolumeId' => array( 'type' => 'string', ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', ), ), ), ), ), ), 'DescribeLayersResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Layers' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Layer', 'type' => 'object', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'LayerId' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Shortname' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'CustomInstanceProfileArn' => array( 'type' => 'string', ), 'CustomSecurityGroupIds' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'DefaultSecurityGroupNames' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Packages' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'VolumeConfigurations' => array( 'type' => 'array', 'items' => array( 'name' => 'VolumeConfiguration', 'type' => 'object', 'properties' => array( 'MountPoint' => array( 'type' => 'string', ), 'RaidLevel' => array( 'type' => 'numeric', ), 'NumberOfDisks' => array( 'type' => 'numeric', ), 'Size' => array( 'type' => 'numeric', ), ), ), ), 'EnableAutoHealing' => array( 'type' => 'boolean', ), 'AutoAssignElasticIps' => array( 'type' => 'boolean', ), 'AutoAssignPublicIps' => array( 'type' => 'boolean', ), 'DefaultRecipes' => array( 'type' => 'object', 'properties' => array( 'Setup' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Configure' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Deploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Undeploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Shutdown' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'CustomRecipes' => array( 'type' => 'object', 'properties' => array( 'Setup' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Configure' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Deploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Undeploy' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'Shutdown' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), 'CreatedAt' => array( 'type' => 'string', ), 'InstallUpdatesOnBoot' => array( 'type' => 'boolean', ), ), ), ), ), ), 'DescribeLoadBasedAutoScalingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoadBasedAutoScalingConfigurations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'LoadBasedAutoScalingConfiguration', 'type' => 'object', 'properties' => array( 'LayerId' => array( 'type' => 'string', ), 'Enable' => array( 'type' => 'boolean', ), 'UpScaling' => array( 'type' => 'object', 'properties' => array( 'InstanceCount' => array( 'type' => 'numeric', ), 'ThresholdsWaitTime' => array( 'type' => 'numeric', ), 'IgnoreMetricsTime' => array( 'type' => 'numeric', ), 'CpuThreshold' => array( 'type' => 'numeric', ), 'MemoryThreshold' => array( 'type' => 'numeric', ), 'LoadThreshold' => array( 'type' => 'numeric', ), ), ), 'DownScaling' => array( 'type' => 'object', 'properties' => array( 'InstanceCount' => array( 'type' => 'numeric', ), 'ThresholdsWaitTime' => array( 'type' => 'numeric', ), 'IgnoreMetricsTime' => array( 'type' => 'numeric', ), 'CpuThreshold' => array( 'type' => 'numeric', ), 'MemoryThreshold' => array( 'type' => 'numeric', ), 'LoadThreshold' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), 'DescribeMyUserProfileResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UserProfile' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'IamUserArn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'SshUsername' => array( 'type' => 'string', ), 'SshPublicKey' => array( 'type' => 'string', ), ), ), ), ), 'DescribePermissionsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Permissions' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Permission', 'type' => 'object', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'IamUserArn' => array( 'type' => 'string', ), 'AllowSsh' => array( 'type' => 'boolean', ), 'AllowSudo' => array( 'type' => 'boolean', ), 'Level' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeRaidArraysResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RaidArrays' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'RaidArray', 'type' => 'object', 'properties' => array( 'RaidArrayId' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'RaidLevel' => array( 'type' => 'numeric', ), 'NumberOfDisks' => array( 'type' => 'numeric', ), 'Size' => array( 'type' => 'numeric', ), 'Device' => array( 'type' => 'string', ), 'MountPoint' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeServiceErrorsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ServiceErrors' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ServiceError', 'type' => 'object', 'properties' => array( 'ServiceErrorId' => array( 'type' => 'string', ), 'StackId' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeStackSummaryResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StackSummary' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'LayersCount' => array( 'type' => 'numeric', ), 'AppsCount' => array( 'type' => 'numeric', ), 'InstancesCount' => array( 'type' => 'object', 'properties' => array( 'Booting' => array( 'type' => 'numeric', ), 'ConnectionLost' => array( 'type' => 'numeric', ), 'Pending' => array( 'type' => 'numeric', ), 'Rebooting' => array( 'type' => 'numeric', ), 'Requested' => array( 'type' => 'numeric', ), 'RunningSetup' => array( 'type' => 'numeric', ), 'SetupFailed' => array( 'type' => 'numeric', ), 'ShuttingDown' => array( 'type' => 'numeric', ), 'StartFailed' => array( 'type' => 'numeric', ), 'Stopped' => array( 'type' => 'numeric', ), 'Terminated' => array( 'type' => 'numeric', ), 'Terminating' => array( 'type' => 'numeric', ), ), ), ), ), ), ), 'DescribeStacksResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Stacks' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Stack', 'type' => 'object', 'properties' => array( 'StackId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'Region' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'ServiceRoleArn' => array( 'type' => 'string', ), 'DefaultInstanceProfileArn' => array( 'type' => 'string', ), 'DefaultOs' => array( 'type' => 'string', ), 'HostnameTheme' => array( 'type' => 'string', ), 'DefaultAvailabilityZone' => array( 'type' => 'string', ), 'DefaultSubnetId' => array( 'type' => 'string', ), 'CustomJson' => array( 'type' => 'string', ), 'ConfigurationManager' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Version' => array( 'type' => 'string', ), ), ), 'UseCustomCookbooks' => array( 'type' => 'boolean', ), 'CustomCookbooksSource' => array( 'type' => 'object', 'properties' => array( 'Type' => array( 'type' => 'string', ), 'Url' => array( 'type' => 'string', ), 'Username' => array( 'type' => 'string', ), 'Password' => array( 'type' => 'string', ), 'SshKey' => array( 'type' => 'string', ), 'Revision' => array( 'type' => 'string', ), ), ), 'DefaultSshKeyName' => array( 'type' => 'string', ), 'CreatedAt' => array( 'type' => 'string', ), 'DefaultRootDeviceType' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeTimeBasedAutoScalingResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TimeBasedAutoScalingConfigurations' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TimeBasedAutoScalingConfiguration', 'type' => 'object', 'properties' => array( 'InstanceId' => array( 'type' => 'string', ), 'AutoScalingSchedule' => array( 'type' => 'object', 'properties' => array( 'Monday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Tuesday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Wednesday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Thursday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Friday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Saturday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), 'Sunday' => array( 'type' => 'object', 'additionalProperties' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeUserProfilesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'UserProfiles' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'UserProfile', 'type' => 'object', 'properties' => array( 'IamUserArn' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'SshUsername' => array( 'type' => 'string', ), 'SshPublicKey' => array( 'type' => 'string', ), 'AllowSelfManagement' => array( 'type' => 'boolean', ), ), ), ), ), ), 'DescribeVolumesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Volumes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Volume', 'type' => 'object', 'properties' => array( 'VolumeId' => array( 'type' => 'string', ), 'Ec2VolumeId' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'RaidArrayId' => array( 'type' => 'string', ), 'InstanceId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Size' => array( 'type' => 'numeric', ), 'Device' => array( 'type' => 'string', ), 'MountPoint' => array( 'type' => 'string', ), 'Region' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), ), ), ), ), ), 'GetHostnameSuggestionResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LayerId' => array( 'type' => 'string', 'location' => 'json', ), 'Hostname' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'RegisterElasticIpResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ElasticIp' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'RegisterVolumeResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeId' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeApps' => array( 'result_key' => 'Apps', ), 'DescribeCommands' => array( 'result_key' => 'Commands', ), 'DescribeDeployments' => array( 'result_key' => 'Deployments', ), 'DescribeElasticIps' => array( 'result_key' => 'ElasticIps', ), 'DescribeElasticLoadBalancers' => array( 'result_key' => 'ElasticLoadBalancers', ), 'DescribeInstances' => array( 'result_key' => 'Instances', ), 'DescribeLayers' => array( 'result_key' => 'Layers', ), 'DescribeLoadBasedAutoScaling' => array( 'result_key' => 'LoadBasedAutoScalingConfigurations', ), 'DescribeRaidArrays' => array( 'result_key' => 'RaidArrays', ), 'DescribeServiceErrors' => array( 'result_key' => 'ServiceErrors', ), 'DescribeStacks' => array( 'result_key' => 'Stacks', ), 'DescribeTimeBasedAutoScaling' => array( 'result_key' => 'TimeBasedAutoScalingConfigurations', ), 'DescribeUserProfiles' => array( 'result_key' => 'UserProfiles', ), 'DescribeVolumes' => array( 'result_key' => 'Volumes', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/rds-%s.php' )) ->build(); } } '2013-09-09', 'endpointPrefix' => 'rds', 'serviceFullName' => 'Amazon Relational Database Service', 'serviceAbbreviation' => 'Amazon RDS', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Rds', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'rds.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AddSourceIdentifierToSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddSourceIdentifierToSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'The requested source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'AddTagsToResource' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddTagsToResource', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ResourceName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'AuthorizeDBSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeDBSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CIDRIP' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'The state of the DB security group does not allow deletion.', 'class' => 'InvalidDBSecurityGroupStateException', ), array( 'reason' => 'The specified CIDRIP or EC2 security group is already authorized for the specified DB security group.', 'class' => 'AuthorizationAlreadyExistsException', ), array( 'reason' => 'DB security group authorization quota has been reached.', 'class' => 'AuthorizationQuotaExceededException', ), ), ), 'CopyDBSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CopyDBSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SourceDBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TargetDBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBSnapshotIdentifier is already used by an existing snapshot.', 'class' => 'DBSnapshotAlreadyExistsException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), array( 'reason' => 'The state of the DB snapshot does not allow deletion.', 'class' => 'InvalidDBSnapshotStateException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB snapshots.', 'class' => 'SnapshotQuotaExceededException', ), ), ), 'CreateDBInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AllocatedStorage' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Engine' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MasterUsername' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MasterUserPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DBSecurityGroups.member', 'items' => array( 'name' => 'DBSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcSecurityGroupIds.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PreferredBackupWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseModel' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'CharacterSetName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB instances.', 'class' => 'InstanceQuotaExceededException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'CreateDBInstanceReadReplica' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBInstanceReadReplica', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceDBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB instances.', 'class' => 'InstanceQuotaExceededException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), array( 'reason' => 'Indicates that the DBSubnetGroup should not be specified while creating read replicas that lie in the same region as the source instance.', 'class' => 'DBSubnetGroupNotAllowedException', ), array( 'reason' => 'Indicates the DBSubnetGroup does not belong to the same VPC as that of an existing cross region read replica of the same source instance.', 'class' => 'InvalidDBSubnetGroupException', ), ), ), 'CreateDBParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Request would result in user exceeding the allowed number of DB parameter groups.', 'class' => 'DBParameterGroupQuotaExceededException', ), array( 'reason' => 'A DB parameter group with the same name exists.', 'class' => 'DBParameterGroupAlreadyExistsException', ), ), ), 'CreateDBSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSecurityGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'A DB security group with the name specified in DBSecurityGroupName already exists.', 'class' => 'DBSecurityGroupAlreadyExistsException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB security groups.', 'class' => 'DBSecurityGroupQuotaExceededException', ), array( 'reason' => 'A DB security group is not allowed for this action.', 'class' => 'DBSecurityGroupNotSupportedException', ), ), ), 'CreateDBSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBSnapshotIdentifier is already used by an existing snapshot.', 'class' => 'DBSnapshotAlreadyExistsException', ), array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB snapshots.', 'class' => 'SnapshotQuotaExceededException', ), ), ), 'CreateDBSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDBSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBSubnetGroupName is already used by an existing DB subnet group.', 'class' => 'DBSubnetGroupAlreadyExistsException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB subnet groups.', 'class' => 'DBSubnetGroupQuotaExceededException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of subnets in a DB subnet groups.', 'class' => 'DBSubnetQuotaExceededException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), ), ), 'CreateEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'SourceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SourceIds.member', 'items' => array( 'name' => 'SourceId', 'type' => 'string', ), ), 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'You have reached the maximum number of event subscriptions.', 'class' => 'EventSubscriptionQuotaExceededException', ), array( 'reason' => 'The supplied subscription name already exists.', 'class' => 'SubscriptionAlreadyExistException', ), array( 'reason' => 'SNS has responded that there is a problem with the SND topic specified.', 'class' => 'SNSInvalidTopicException', ), array( 'reason' => 'You do not have permission to publish to the SNS topic ARN.', 'class' => 'SNSNoAuthorizationException', ), array( 'reason' => 'The SNS topic ARN does not exist.', 'class' => 'SNSTopicArnNotFoundException', ), array( 'reason' => 'The supplied category does not exist.', 'class' => 'SubscriptionCategoryNotFoundException', ), array( 'reason' => 'The requested source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'CreateOptionGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OptionGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateOptionGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'OptionGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EngineName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MajorEngineVersion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'OptionGroupDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The option group you are trying to create already exists.', 'class' => 'OptionGroupAlreadyExistsException', ), array( 'reason' => 'The quota of 20 option groups was exceeded for this AWS account.', 'class' => 'OptionGroupQuotaExceededException', ), ), ), 'DeleteDBInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SkipFinalSnapshot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'FinalDBSnapshotIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBSnapshotIdentifier is already used by an existing snapshot.', 'class' => 'DBSnapshotAlreadyExistsException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB snapshots.', 'class' => 'SnapshotQuotaExceededException', ), ), ), 'DeleteDBParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The DB parameter group cannot be deleted because it is in use.', 'class' => 'InvalidDBParameterGroupStateException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), ), ), 'DeleteDBSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The state of the DB security group does not allow deletion.', 'class' => 'InvalidDBSecurityGroupStateException', ), array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), ), ), 'DeleteDBSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The state of the DB snapshot does not allow deletion.', 'class' => 'InvalidDBSnapshotStateException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'DeleteDBSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDBSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The DB subnet group cannot be deleted because it is in use.', 'class' => 'InvalidDBSubnetGroupStateException', ), array( 'reason' => 'The DB subnet is not in the available state.', 'class' => 'InvalidDBSubnetStateException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), ), ), 'DeleteEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'This error can occur if someone else is modifying a subscription. You should retry the action.', 'class' => 'InvalidEventSubscriptionStateException', ), ), ), 'DeleteOptionGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteOptionGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'OptionGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), array( 'reason' => 'The option group is not in the available state.', 'class' => 'InvalidOptionGroupStateException', ), ), ), 'DescribeDBEngineVersions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBEngineVersionMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBEngineVersions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'Engine' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBParameterGroupFamily' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DefaultOnly' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ListSupportedCharacterSets' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'DescribeDBInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'DescribeDBLogFiles' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DescribeDBLogFilesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBLogFiles', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'FilenameContains' => array( 'type' => 'string', 'location' => 'aws.query', ), 'FileLastWritten' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'FileSize' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'DescribeDBParameterGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBParameterGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), ), ), 'DescribeDBParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupDetails', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Source' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), ), ), 'DescribeDBSecurityGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSecurityGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBSecurityGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), ), ), 'DescribeDBSnapshots' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSnapshotMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBSnapshots', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSnapshotIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'DescribeDBSubnetGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSubnetGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDBSubnetGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), ), ), 'DescribeEngineDefaultParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EngineDefaultsWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEngineDefaultParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeEventCategories' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventCategoriesMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEventCategories', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeEventSubscriptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEventSubscriptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), ), ), 'DescribeEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SourceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeOptionGroupOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OptionGroupOptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeOptionGroupOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'EngineName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MajorEngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeOptionGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OptionGroups', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeOptionGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'EngineName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MajorEngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'DescribeOrderableDBInstanceOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OrderableDBInstanceOptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeOrderableDBInstanceOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'Engine' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'LicenseModel' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Vpc' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeReservedDBInstances' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedDBInstanceMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedDBInstances', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ReservedDBInstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Filters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Filters.member', 'items' => array( 'name' => 'Filter', 'type' => 'object', 'properties' => array( 'FilterName' => array( 'required' => true, 'type' => 'string', ), 'FilterValue' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'FilterValue.member', 'items' => array( 'name' => 'Value', 'type' => 'string', ), ), ), ), ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified reserved DB Instance not found.', 'class' => 'ReservedDBInstanceNotFoundException', ), ), ), 'DescribeReservedDBInstancesOfferings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedDBInstancesOfferingMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedDBInstancesOfferings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ProductDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OfferingType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Specified offering does not exist.', 'class' => 'ReservedDBInstancesOfferingNotFoundException', ), ), ), 'DownloadDBLogFilePortion' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DownloadDBLogFilePortionDetails', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DownloadDBLogFilePortion', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'LogFileName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NumberOfLines' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'ListTagsForResource' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'TagListMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListTagsForResource', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ResourceName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'ModifyDBInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyDBInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AllocatedStorage' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DBSecurityGroups.member', 'items' => array( 'name' => 'DBSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcSecurityGroupIds.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'ApplyImmediately' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'MasterUserPassword' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PreferredBackupWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'EngineVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowMajorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NewDBInstanceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'The state of the DB security group does not allow deletion.', 'class' => 'InvalidDBSecurityGroupStateException', ), array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), array( 'reason' => 'The DB upgrade failed because a resource the DB depends on could not be modified.', 'class' => 'DBUpgradeDependencyFailureException', ), ), ), 'ModifyDBParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyDBParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Parameters' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'ApplyMethod' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), array( 'reason' => 'The DB parameter group cannot be deleted because it is in use.', 'class' => 'InvalidDBParameterGroupStateException', ), ), ), 'ModifyDBSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyDBSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of subnets in a DB subnet groups.', 'class' => 'DBSubnetQuotaExceededException', ), array( 'reason' => 'The DB subnet is already in use in the Availability Zone.', 'class' => 'SubnetAlreadyInUseException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), ), ), 'ModifyEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'You have reached the maximum number of event subscriptions.', 'class' => 'EventSubscriptionQuotaExceededException', ), array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'SNS has responded that there is a problem with the SND topic specified.', 'class' => 'SNSInvalidTopicException', ), array( 'reason' => 'You do not have permission to publish to the SNS topic ARN.', 'class' => 'SNSNoAuthorizationException', ), array( 'reason' => 'The SNS topic ARN does not exist.', 'class' => 'SNSTopicArnNotFoundException', ), array( 'reason' => 'The supplied category does not exist.', 'class' => 'SubscriptionCategoryNotFoundException', ), ), ), 'ModifyOptionGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OptionGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyOptionGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'OptionGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'OptionsToInclude' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToInclude.member', 'items' => array( 'name' => 'OptionConfiguration', 'type' => 'object', 'properties' => array( 'OptionName' => array( 'required' => true, 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'DBSecurityGroupMemberships' => array( 'type' => 'array', 'sentAs' => 'DBSecurityGroupMemberships.member', 'items' => array( 'name' => 'DBSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupMemberships' => array( 'type' => 'array', 'sentAs' => 'VpcSecurityGroupMemberships.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'OptionSettings' => array( 'type' => 'array', 'sentAs' => 'OptionSettings.member', 'items' => array( 'name' => 'OptionSetting', 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'IsCollection' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), ), ), 'OptionsToRemove' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'OptionsToRemove.member', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), 'ApplyImmediately' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The option group is not in the available state.', 'class' => 'InvalidOptionGroupStateException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'PromoteReadReplica' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PromoteReadReplica', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PreferredBackupWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'PurchaseReservedDBInstancesOffering' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedDBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PurchaseReservedDBInstancesOffering', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ReservedDBInstancesOfferingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReservedDBInstanceId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Specified offering does not exist.', 'class' => 'ReservedDBInstancesOfferingNotFoundException', ), array( 'reason' => 'User already has a reservation with the given identifier.', 'class' => 'ReservedDBInstanceAlreadyExistsException', ), array( 'reason' => 'Request would exceed the user\'s DB Instance quota.', 'class' => 'ReservedDBInstanceQuotaExceededException', ), ), ), 'RebootDBInstance' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebootDBInstance', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ForceFailover' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), ), ), 'RemoveSourceIdentifierFromSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemoveSourceIdentifierFromSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The subscription name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'The requested source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'RemoveTagsFromResource' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemoveTagsFromResource', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'ResourceName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TagKeys' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'TagKeys.member', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), ), ), 'ResetDBParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetDBParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ResetAllParameters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'ApplyMethod' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The DB parameter group cannot be deleted because it is in use.', 'class' => 'InvalidDBParameterGroupStateException', ), array( 'reason' => 'DBParameterGroupName does not refer to an existing DB parameter group.', 'class' => 'DBParameterGroupNotFoundException', ), ), ), 'RestoreDBInstanceFromDBSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RestoreDBInstanceFromDBSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseModel' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Engine' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'DBSnapshotIdentifier does not refer to an existing DB snapshot.', 'class' => 'DBSnapshotNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB instances.', 'class' => 'InstanceQuotaExceededException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'The state of the DB snapshot does not allow deletion.', 'class' => 'InvalidDBSnapshotStateException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Cannot restore from vpc backup to non-vpc DB instance.', 'class' => 'InvalidRestoreException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'RestoreDBInstanceToPointInTime' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBInstanceWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RestoreDBInstanceToPointInTime', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'SourceDBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'TargetDBInstanceIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RestoreTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'UseLatestRestorableTime' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'DBInstanceClass' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MultiAZ' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'LicenseModel' => array( 'type' => 'string', 'location' => 'aws.query', ), 'DBName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Engine' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Iops' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'OptionGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Tags' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Tags.member', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'User already has a DB instance with the given identifier.', 'class' => 'DBInstanceAlreadyExistsException', ), array( 'reason' => 'DBInstanceIdentifier does not refer to an existing DB instance.', 'class' => 'DBInstanceNotFoundException', ), array( 'reason' => 'Request would result in user exceeding the allowed number of DB instances.', 'class' => 'InstanceQuotaExceededException', ), array( 'reason' => 'Specified DB instance class is not available in the specified Availability Zone.', 'class' => 'InsufficientDBInstanceCapacityException', ), array( 'reason' => 'The specified DB instance is not in the available state.', 'class' => 'InvalidDBInstanceStateException', ), array( 'reason' => 'SourceDBInstanceIdentifier refers to a DB instance with BackupRetentionPeriod equal to 0.', 'class' => 'PointInTimeRestoreNotEnabledException', ), array( 'reason' => 'Request would result in user exceeding the allowed amount of storage available across all DB instances.', 'class' => 'StorageQuotaExceededException', ), array( 'reason' => 'DB subnet group does not cover all Availability Zones after it is created because users\' change.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'Cannot restore from vpc backup to non-vpc DB instance.', 'class' => 'InvalidRestoreException', ), array( 'reason' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', 'class' => 'DBSubnetGroupNotFoundException', ), array( 'reason' => 'Subnets in the DB subnet group should cover at least 2 Availability Zones unless there is only 1 availablility zone.', 'class' => 'DBSubnetGroupDoesNotCoverEnoughAZsException', ), array( 'reason' => 'The requested subnet is invalid, or multiple subnets were requested that are not all in a common VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Provisioned IOPS not available in the specified Availability Zone.', 'class' => 'ProvisionedIopsNotAvailableInAZException', ), array( 'reason' => 'The specified option group could not be found.', 'class' => 'OptionGroupNotFoundException', ), ), ), 'RevokeDBSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DBSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeDBSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2013-09-09', ), 'DBSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CIDRIP' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'DBSecurityGroupName does not refer to an existing DB security group.', 'class' => 'DBSecurityGroupNotFoundException', ), array( 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group.', 'class' => 'AuthorizationNotFoundException', ), array( 'reason' => 'The state of the DB security group does not allow deletion.', 'class' => 'InvalidDBSecurityGroupStateException', ), ), ), ), 'models' => array( 'EventSubscriptionWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EventSubscription' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CustomerAwsId' => array( 'type' => 'string', ), 'CustSubscriptionId' => array( 'type' => 'string', ), 'SnsTopicArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubscriptionCreationTime' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'SourceIdsList' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceId', 'type' => 'string', 'sentAs' => 'SourceId', ), ), 'EventCategoriesList' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DBSecurityGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBSecurityGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'OwnerId' => array( 'type' => 'string', ), 'DBSecurityGroupName' => array( 'type' => 'string', ), 'DBSecurityGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupId' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), 'IPRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IPRange', 'type' => 'object', 'sentAs' => 'IPRange', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CIDRIP' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DBSnapshotWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBSnapshot' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBSnapshotIdentifier' => array( 'type' => 'string', ), 'DBInstanceIdentifier' => array( 'type' => 'string', ), 'SnapshotCreateTime' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'Status' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'InstanceCreateTime' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'LicenseModel' => array( 'type' => 'string', ), 'SnapshotType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'OptionGroupName' => array( 'type' => 'string', ), 'PercentProgress' => array( 'type' => 'numeric', ), 'SourceRegion' => array( 'type' => 'string', ), ), ), ), ), 'DBInstanceWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBInstance' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBInstanceIdentifier' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'DBInstanceStatus' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'DBName' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'InstanceCreateTime' => array( 'type' => 'string', ), 'PreferredBackupWindow' => array( 'type' => 'string', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', ), 'DBSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'DBSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroupMembership', 'type' => 'object', 'sentAs' => 'VpcSecurityGroupMembership', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'DBParameterGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'DBParameterGroup', 'type' => 'object', 'sentAs' => 'DBParameterGroup', 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), ), ), ), 'AvailabilityZone' => array( 'type' => 'string', ), 'DBSubnetGroup' => array( 'type' => 'object', 'properties' => array( 'DBSubnetGroupName' => array( 'type' => 'string', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'DBInstanceClass' => array( 'type' => 'string', ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'MasterUserPassword' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'EngineVersion' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'DBInstanceIdentifier' => array( 'type' => 'string', ), ), ), 'LatestRestorableTime' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'EngineVersion' => array( 'type' => 'string', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', ), 'ReadReplicaSourceDBInstanceIdentifier' => array( 'type' => 'string', ), 'ReadReplicaDBInstanceIdentifiers' => array( 'type' => 'array', 'items' => array( 'name' => 'ReadReplicaDBInstanceIdentifier', 'type' => 'string', 'sentAs' => 'ReadReplicaDBInstanceIdentifier', ), ), 'LicenseModel' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'OptionGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionGroupMembership', 'type' => 'object', 'sentAs' => 'OptionGroupMembership', 'properties' => array( 'OptionGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'CharacterSetName' => array( 'type' => 'string', ), 'SecondaryAvailabilityZone' => array( 'type' => 'string', ), 'PubliclyAccessible' => array( 'type' => 'boolean', ), 'StatusInfos' => array( 'type' => 'array', 'items' => array( 'name' => 'DBInstanceStatusInfo', 'type' => 'object', 'sentAs' => 'DBInstanceStatusInfo', 'properties' => array( 'StatusType' => array( 'type' => 'string', ), 'Normal' => array( 'type' => 'boolean', ), 'Status' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DBParameterGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBParameterGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', ), 'DBParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), 'DBSubnetGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBSubnetGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBSubnetGroupName' => array( 'type' => 'string', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'OptionGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OptionGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'OptionGroupName' => array( 'type' => 'string', ), 'OptionGroupDescription' => array( 'type' => 'string', ), 'EngineName' => array( 'type' => 'string', ), 'MajorEngineVersion' => array( 'type' => 'string', ), 'Options' => array( 'type' => 'array', 'items' => array( 'name' => 'Option', 'type' => 'object', 'sentAs' => 'Option', 'properties' => array( 'OptionName' => array( 'type' => 'string', ), 'OptionDescription' => array( 'type' => 'string', ), 'Persistent' => array( 'type' => 'boolean', ), 'Permanent' => array( 'type' => 'boolean', ), 'Port' => array( 'type' => 'numeric', ), 'OptionSettings' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionSetting', 'type' => 'object', 'sentAs' => 'OptionSetting', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'IsCollection' => array( 'type' => 'boolean', ), ), ), ), 'DBSecurityGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'DBSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroupMembership', 'type' => 'object', 'sentAs' => 'VpcSecurityGroupMembership', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), ), ), ), 'AllowsVpcAndNonVpcInstanceMemberships' => array( 'type' => 'boolean', ), 'VpcId' => array( 'type' => 'string', ), ), ), ), ), 'DBEngineVersionMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBEngineVersions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBEngineVersion', 'type' => 'object', 'sentAs' => 'DBEngineVersion', 'properties' => array( 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'DBParameterGroupFamily' => array( 'type' => 'string', ), 'DBEngineDescription' => array( 'type' => 'string', ), 'DBEngineVersionDescription' => array( 'type' => 'string', ), 'DefaultCharacterSet' => array( 'type' => 'object', 'properties' => array( 'CharacterSetName' => array( 'type' => 'string', ), 'CharacterSetDescription' => array( 'type' => 'string', ), ), ), 'SupportedCharacterSets' => array( 'type' => 'array', 'items' => array( 'name' => 'CharacterSet', 'type' => 'object', 'sentAs' => 'CharacterSet', 'properties' => array( 'CharacterSetName' => array( 'type' => 'string', ), 'CharacterSetDescription' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DBInstanceMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBInstances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBInstance', 'type' => 'object', 'sentAs' => 'DBInstance', 'properties' => array( 'DBInstanceIdentifier' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'DBInstanceStatus' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'DBName' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'InstanceCreateTime' => array( 'type' => 'string', ), 'PreferredBackupWindow' => array( 'type' => 'string', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', ), 'DBSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'DBSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroupMembership', 'type' => 'object', 'sentAs' => 'VpcSecurityGroupMembership', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'DBParameterGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'DBParameterGroup', 'type' => 'object', 'sentAs' => 'DBParameterGroup', 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), ), ), ), 'AvailabilityZone' => array( 'type' => 'string', ), 'DBSubnetGroup' => array( 'type' => 'object', 'properties' => array( 'DBSubnetGroupName' => array( 'type' => 'string', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'DBInstanceClass' => array( 'type' => 'string', ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'MasterUserPassword' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'BackupRetentionPeriod' => array( 'type' => 'numeric', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'EngineVersion' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'DBInstanceIdentifier' => array( 'type' => 'string', ), ), ), 'LatestRestorableTime' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'EngineVersion' => array( 'type' => 'string', ), 'AutoMinorVersionUpgrade' => array( 'type' => 'boolean', ), 'ReadReplicaSourceDBInstanceIdentifier' => array( 'type' => 'string', ), 'ReadReplicaDBInstanceIdentifiers' => array( 'type' => 'array', 'items' => array( 'name' => 'ReadReplicaDBInstanceIdentifier', 'type' => 'string', 'sentAs' => 'ReadReplicaDBInstanceIdentifier', ), ), 'LicenseModel' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'OptionGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionGroupMembership', 'type' => 'object', 'sentAs' => 'OptionGroupMembership', 'properties' => array( 'OptionGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'CharacterSetName' => array( 'type' => 'string', ), 'SecondaryAvailabilityZone' => array( 'type' => 'string', ), 'PubliclyAccessible' => array( 'type' => 'boolean', ), 'StatusInfos' => array( 'type' => 'array', 'items' => array( 'name' => 'DBInstanceStatusInfo', 'type' => 'object', 'sentAs' => 'DBInstanceStatusInfo', 'properties' => array( 'StatusType' => array( 'type' => 'string', ), 'Normal' => array( 'type' => 'boolean', ), 'Status' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeDBLogFilesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DescribeDBLogFiles' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DescribeDBLogFilesDetails', 'type' => 'object', 'sentAs' => 'DescribeDBLogFilesDetails', 'properties' => array( 'LogFileName' => array( 'type' => 'string', ), 'LastWritten' => array( 'type' => 'numeric', ), 'Size' => array( 'type' => 'numeric', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DBParameterGroupsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBParameterGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBParameterGroup', 'type' => 'object', 'sentAs' => 'DBParameterGroup', 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', ), 'DBParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'DBParameterGroupDetails' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Parameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'ApplyMethod' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DBSecurityGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBSecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'OwnerId' => array( 'type' => 'string', ), 'DBSecurityGroupName' => array( 'type' => 'string', ), 'DBSecurityGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupId' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), 'IPRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IPRange', 'type' => 'object', 'sentAs' => 'IPRange', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CIDRIP' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DBSnapshotMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBSnapshots' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBSnapshot', 'type' => 'object', 'sentAs' => 'DBSnapshot', 'properties' => array( 'DBSnapshotIdentifier' => array( 'type' => 'string', ), 'DBInstanceIdentifier' => array( 'type' => 'string', ), 'SnapshotCreateTime' => array( 'type' => 'string', ), 'Engine' => array( 'type' => 'string', ), 'AllocatedStorage' => array( 'type' => 'numeric', ), 'Status' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'InstanceCreateTime' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'LicenseModel' => array( 'type' => 'string', ), 'SnapshotType' => array( 'type' => 'string', ), 'Iops' => array( 'type' => 'numeric', ), 'OptionGroupName' => array( 'type' => 'string', ), 'PercentProgress' => array( 'type' => 'numeric', ), 'SourceRegion' => array( 'type' => 'string', ), ), ), ), ), ), 'DBSubnetGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'DBSubnetGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'DBSubnetGroup', 'type' => 'object', 'sentAs' => 'DBSubnetGroup', 'properties' => array( 'DBSubnetGroupName' => array( 'type' => 'string', ), 'DBSubnetGroupDescription' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'EngineDefaultsWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EngineDefaults' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'DBParameterGroupFamily' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), 'Parameters' => array( 'type' => 'array', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), 'ApplyMethod' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EventCategoriesMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EventCategoriesMapList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventCategoriesMap', 'type' => 'object', 'sentAs' => 'EventCategoriesMap', 'properties' => array( 'SourceType' => array( 'type' => 'string', ), 'EventCategories' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), ), ), ), ), ), 'EventSubscriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'EventSubscriptionsList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventSubscription', 'type' => 'object', 'sentAs' => 'EventSubscription', 'properties' => array( 'CustomerAwsId' => array( 'type' => 'string', ), 'CustSubscriptionId' => array( 'type' => 'string', ), 'SnsTopicArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubscriptionCreationTime' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'SourceIdsList' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceId', 'type' => 'string', 'sentAs' => 'SourceId', ), ), 'EventCategoriesList' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), ), 'EventsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Events' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Event', 'type' => 'object', 'sentAs' => 'Event', 'properties' => array( 'SourceIdentifier' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'EventCategories' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Date' => array( 'type' => 'string', ), ), ), ), ), ), 'OptionGroupOptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OptionGroupOptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'OptionGroupOption', 'type' => 'object', 'sentAs' => 'OptionGroupOption', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EngineName' => array( 'type' => 'string', ), 'MajorEngineVersion' => array( 'type' => 'string', ), 'MinimumRequiredMinorEngineVersion' => array( 'type' => 'string', ), 'PortRequired' => array( 'type' => 'boolean', ), 'DefaultPort' => array( 'type' => 'numeric', ), 'OptionsDependedOn' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionName', 'type' => 'string', 'sentAs' => 'OptionName', ), ), 'Persistent' => array( 'type' => 'boolean', ), 'Permanent' => array( 'type' => 'boolean', ), 'OptionGroupOptionSettings' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionGroupOptionSetting', 'type' => 'object', 'sentAs' => 'OptionGroupOptionSetting', 'properties' => array( 'SettingName' => array( 'type' => 'string', ), 'SettingDescription' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'OptionGroups' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OptionGroupsList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'OptionGroup', 'type' => 'object', 'sentAs' => 'OptionGroup', 'properties' => array( 'OptionGroupName' => array( 'type' => 'string', ), 'OptionGroupDescription' => array( 'type' => 'string', ), 'EngineName' => array( 'type' => 'string', ), 'MajorEngineVersion' => array( 'type' => 'string', ), 'Options' => array( 'type' => 'array', 'items' => array( 'name' => 'Option', 'type' => 'object', 'sentAs' => 'Option', 'properties' => array( 'OptionName' => array( 'type' => 'string', ), 'OptionDescription' => array( 'type' => 'string', ), 'Persistent' => array( 'type' => 'boolean', ), 'Permanent' => array( 'type' => 'boolean', ), 'Port' => array( 'type' => 'numeric', ), 'OptionSettings' => array( 'type' => 'array', 'items' => array( 'name' => 'OptionSetting', 'type' => 'object', 'sentAs' => 'OptionSetting', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'DefaultValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'ApplyType' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'IsCollection' => array( 'type' => 'boolean', ), ), ), ), 'DBSecurityGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'DBSecurityGroup', 'type' => 'object', 'sentAs' => 'DBSecurityGroup', 'properties' => array( 'DBSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroupMemberships' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroupMembership', 'type' => 'object', 'sentAs' => 'VpcSecurityGroupMembership', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), ), ), ), 'AllowsVpcAndNonVpcInstanceMemberships' => array( 'type' => 'boolean', ), 'VpcId' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'OrderableDBInstanceOptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OrderableDBInstanceOptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'OrderableDBInstanceOption', 'type' => 'object', 'sentAs' => 'OrderableDBInstanceOption', 'properties' => array( 'Engine' => array( 'type' => 'string', ), 'EngineVersion' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'LicenseModel' => array( 'type' => 'string', ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'object', 'sentAs' => 'AvailabilityZone', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'ProvisionedIopsCapable' => array( 'type' => 'boolean', ), ), ), ), 'MultiAZCapable' => array( 'type' => 'boolean', ), 'ReadReplicaCapable' => array( 'type' => 'boolean', ), 'Vpc' => array( 'type' => 'boolean', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedDBInstanceMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedDBInstances' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedDBInstance', 'type' => 'object', 'sentAs' => 'ReservedDBInstance', 'properties' => array( 'ReservedDBInstanceId' => array( 'type' => 'string', ), 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'DBInstanceCount' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'State' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ReservedDBInstancesOfferingMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedDBInstancesOfferings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedDBInstancesOffering', 'type' => 'object', 'sentAs' => 'ReservedDBInstancesOffering', 'properties' => array( 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DownloadDBLogFilePortionDetails' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LogFileData' => array( 'type' => 'string', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'AdditionalDataPending' => array( 'type' => 'boolean', 'location' => 'xml', ), ), ), 'TagListMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TagList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'sentAs' => 'Tag', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), ), ), 'DBParameterGroupNameMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DBParameterGroupName' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedDBInstanceWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedDBInstance' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ReservedDBInstanceId' => array( 'type' => 'string', ), 'ReservedDBInstancesOfferingId' => array( 'type' => 'string', ), 'DBInstanceClass' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'DBInstanceCount' => array( 'type' => 'numeric', ), 'ProductDescription' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'MultiAZ' => array( 'type' => 'boolean', ), 'State' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeDBEngineVersions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBEngineVersions', ), 'DescribeDBInstances' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBInstances', ), 'DescribeDBLogFiles' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DescribeDBLogFiles', ), 'DescribeDBParameterGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBParameterGroups', ), 'DescribeDBParameters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Parameters', ), 'DescribeDBSecurityGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBSecurityGroups', ), 'DescribeDBSnapshots' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBSnapshots', ), 'DescribeDBSubnetGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'DBSubnetGroups', ), 'DescribeEngineDefaultParameters' => array( 'token_param' => 'Marker', 'limit_key' => 'MaxRecords', ), 'DescribeEventSubscriptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'EventSubscriptionsList', ), 'DescribeEvents' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Events', ), 'DescribeOptionGroupOptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'OptionGroupOptions', ), 'DescribeOptionGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'OptionGroupsList', ), 'DescribeOrderableDBInstanceOptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'OrderableDBInstanceOptions', ), 'DescribeReservedDBInstances' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedDBInstances', ), 'DescribeReservedDBInstancesOfferings' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedDBInstancesOfferings', ), 'DownloadDBLogFilePortion' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', ), 'ListTagsForResource' => array( 'result_key' => 'TagList', ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 30, 'max_attempts' => 60, ), '__DBInstanceState' => array( 'operation' => 'DescribeDBInstances', 'acceptor.path' => 'DBInstances/*/DBInstanceStatus', 'acceptor.type' => 'output', ), 'DBInstanceAvailable' => array( 'extends' => '__DBInstanceState', 'success.value' => 'available', 'failure.value' => array( 'deleted', 'deleting', 'failed', 'incompatible-restore', 'incompatible-parameters', 'incompatible-parameters', 'incompatible-restore', ), ), 'DBInstanceDeleted' => array( 'extends' => '__DBInstanceState', 'success.value' => 'deleted', 'failure.value' => array( 'creating', 'modifying', 'rebooting', 'resetting-master-credentials', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/redshift-%s.php' )) ->build(); } } '2012-12-01', 'endpointPrefix' => 'redshift', 'serviceFullName' => 'Amazon Redshift', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Redshift', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.us-east-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.eu-west-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.ap-southeast-2.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'redshift.ap-northeast-1.amazonaws.com', ), ), 'operations' => array( 'AuthorizeClusterSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeClusterSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CIDRIP' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), array( 'reason' => 'The state of the cluster security group is not "available".', 'class' => 'InvalidClusterSecurityGroupStateException', ), array( 'reason' => 'The specified CIDR block or EC2 security group is already authorized for the specified cluster security group.', 'class' => 'AuthorizationAlreadyExistsException', ), array( 'reason' => 'The authorization quota for the cluster security group has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'AuthorizationQuotaExceededException', ), ), ), 'AuthorizeSnapshotAccess' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AuthorizeSnapshotAccess', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AccountWithRestoreAccess' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), array( 'reason' => 'The specified CIDR block or EC2 security group is already authorized for the specified cluster security group.', 'class' => 'AuthorizationAlreadyExistsException', ), array( 'reason' => 'The authorization quota for the cluster security group has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'AuthorizationQuotaExceededException', ), ), ), 'CopyClusterSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CopyClusterSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SourceSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceSnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'TargetSnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value specified as a snapshot identifier is already used by an existing snapshot.', 'class' => 'ClusterSnapshotAlreadyExistsException', ), array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), array( 'reason' => 'The state of the cluster snapshot is not "available", or other accounts are authorized to access the snapshot.', 'class' => 'InvalidClusterSnapshotStateException', ), array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster snapshots.', 'class' => 'ClusterSnapshotQuotaExceededException', ), ), ), 'CreateCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'DBName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ClusterType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NodeType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MasterUsername' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MasterUserPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ClusterSecurityGroups.member', 'items' => array( 'name' => 'ClusterSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcSecurityGroupIds.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'ClusterSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ClusterVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'NumberOfNodes' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Encrypted' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'HsmClientCertificateIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ElasticIp' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The account already has a cluster with the given identifier.', 'class' => 'ClusterAlreadyExistsException', ), array( 'reason' => 'The number of nodes specified exceeds the allotted capacity of the cluster.', 'class' => 'InsufficientClusterCapacityException', ), array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), array( 'reason' => 'The request would exceed the allowed number of cluster instances for this account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterQuotaExceededException', ), array( 'reason' => 'The operation would exceed the number of nodes allotted to the account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'NumberOfNodesQuotaExceededException', ), array( 'reason' => 'The operation would exceed the number of nodes allowed for a cluster.', 'class' => 'NumberOfNodesPerClusterLimitExceededException', ), array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), array( 'reason' => 'The cluster subnet group does not cover all Availability Zones.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The cluster subnet group cannot be deleted because it is in use.', 'class' => 'InvalidClusterSubnetGroupStateException', ), array( 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), array( 'reason' => 'The Elastic IP (EIP) is invalid or cannot be found.', 'class' => 'InvalidElasticIpException', ), ), ), 'CreateClusterParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateClusterParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster parameter groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterParameterGroupQuotaExceededException', ), array( 'reason' => 'A cluster parameter group with the same name already exists.', 'class' => 'ClusterParameterGroupAlreadyExistsException', ), ), ), 'CreateClusterSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateClusterSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'A cluster security group with the same name already exists.', 'class' => 'ClusterSecurityGroupAlreadyExistsException', ), array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster security groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterSecurityGroupQuotaExceededException', ), ), ), 'CreateClusterSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateClusterSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value specified as a snapshot identifier is already used by an existing snapshot.', 'class' => 'ClusterSnapshotAlreadyExistsException', ), array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster snapshots.', 'class' => 'ClusterSnapshotQuotaExceededException', ), ), ), 'CreateClusterSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateClusterSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'A ClusterSubnetGroupName is already used by an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupAlreadyExistsException', ), array( 'reason' => 'The request would result in user exceeding the allowed number of cluster subnet groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterSubnetGroupQuotaExceededException', ), array( 'reason' => 'The request would result in user exceeding the allowed number of subnets in a cluster subnet groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterSubnetQuotaExceededException', ), array( 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'CreateEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SourceIds.member', 'items' => array( 'name' => 'SourceId', 'type' => 'string', ), ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'Severity' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request would exceed the allowed number of event subscriptions for this account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'EventSubscriptionQuotaExceededException', ), array( 'reason' => 'There is already an existing event notification subscription with the specified name.', 'class' => 'SubscriptionAlreadyExistException', ), array( 'reason' => 'Amazon SNS has responded that there is a problem with the specified Amazon SNS topic.', 'class' => 'SNSInvalidTopicException', ), array( 'reason' => 'You do not have permission to publish to the specified Amazon SNS topic.', 'class' => 'SNSNoAuthorizationException', ), array( 'reason' => 'An Amazon SNS topic with the specified Amazon Resource Name (ARN) does not exist.', 'class' => 'SNSTopicArnNotFoundException', ), array( 'reason' => 'An Amazon Redshift event with the specified event ID does not exist.', 'class' => 'SubscriptionEventIdNotFoundException', ), array( 'reason' => 'The value specified for the event category was not one of the allowed values, or it specified a category that does not apply to the specified source type. The allowed values are Configuration, Management, Monitoring, and Security.', 'class' => 'SubscriptionCategoryNotFoundException', ), array( 'reason' => 'The value specified for the event severity was not one of the allowed values, or it specified a severity that does not apply to the specified source type. The allowed values are ERROR and INFO.', 'class' => 'SubscriptionSeverityNotFoundException', ), array( 'reason' => 'The specified Amazon Redshift event source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'CreateHsmClientCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'HsmClientCertificateWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateHsmClientCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmClientCertificateIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'There is already an existing Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateAlreadyExistsException', ), array( 'reason' => 'The quota for HSM client certificates has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'HsmClientCertificateQuotaExceededException', ), ), ), 'CreateHsmConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'HsmConfigurationWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateHsmConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmConfigurationIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HsmIpAddress' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HsmPartitionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HsmPartitionPassword' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'HsmServerPublicCertificate' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'There is already an existing Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationAlreadyExistsException', ), array( 'reason' => 'The quota for HSM configurations has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'HsmConfigurationQuotaExceededException', ), ), ), 'DeleteCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SkipFinalClusterSnapshot' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'FinalClusterSnapshotIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The value specified as a snapshot identifier is already used by an existing snapshot.', 'class' => 'ClusterSnapshotAlreadyExistsException', ), array( 'reason' => 'The request would result in the user exceeding the allowed number of cluster snapshots.', 'class' => 'ClusterSnapshotQuotaExceededException', ), ), ), 'DeleteClusterParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteClusterParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster parameter group action can not be completed because another task is in progress that involves the parameter group. Wait a few moments and try the operation again.', 'class' => 'InvalidClusterParameterGroupStateException', ), array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), ), ), 'DeleteClusterSecurityGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteClusterSecurityGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The state of the cluster security group is not "available".', 'class' => 'InvalidClusterSecurityGroupStateException', ), array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), ), ), 'DeleteClusterSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteClusterSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The state of the cluster snapshot is not "available", or other accounts are authorized to access the snapshot.', 'class' => 'InvalidClusterSnapshotStateException', ), array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), ), ), 'DeleteClusterSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteClusterSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster subnet group cannot be deleted because it is in use.', 'class' => 'InvalidClusterSubnetGroupStateException', ), array( 'reason' => 'The state of the subnet is invalid.', 'class' => 'InvalidClusterSubnetStateException', ), array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), ), ), 'DeleteEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An Amazon Redshift event notification subscription with the specified name does not exist.', 'class' => 'SubscriptionNotFoundException', ), ), ), 'DeleteHsmClientCertificate' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteHsmClientCertificate', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmClientCertificateIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified HSM client certificate is not in the available state, or it is still in use by one or more Amazon Redshift clusters.', 'class' => 'InvalidHsmClientCertificateStateException', ), array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), ), ), 'DeleteHsmConfiguration' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteHsmConfiguration', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmConfigurationIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified HSM configuration is not in the available state, or it is still in use by one or more Amazon Redshift clusters.', 'class' => 'InvalidHsmConfigurationStateException', ), array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), ), ), 'DescribeClusterParameterGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterParameterGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), ), ), 'DescribeClusterParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupDetails', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Source' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), ), ), 'DescribeClusterSecurityGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSecurityGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterSecurityGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), ), ), 'DescribeClusterSnapshots' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterSnapshots', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), 'OwnerAccount' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), ), ), 'DescribeClusterSubnetGroups' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSubnetGroupMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterSubnetGroups', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), ), ), 'DescribeClusterVersions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterVersionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusterVersions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterParameterGroupFamily' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeClusters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClustersMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeClusters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), ), ), 'DescribeDefaultClusterParameters' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DefaultClusterParametersWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeDefaultClusterParameters', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupFamily' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeEventCategories' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventCategoriesMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEventCategories', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeEventSubscriptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEventSubscriptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SubscriptionName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An Amazon Redshift event notification subscription with the specified name does not exist.', 'class' => 'SubscriptionNotFoundException', ), ), ), 'DescribeEvents' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeEvents', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SourceIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'StartTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'EndTime' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', 'location' => 'aws.query', ), 'Duration' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeHsmClientCertificates' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'HsmClientCertificateMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeHsmClientCertificates', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmClientCertificateIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), ), ), 'DescribeHsmConfigurations' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'HsmConfigurationMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeHsmConfigurations', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), ), ), 'DescribeLoggingStatus' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'LoggingStatus', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeLoggingStatus', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), ), ), 'DescribeOrderableClusterOptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'OrderableClusterOptionsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeOrderableClusterOptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NodeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DescribeReservedNodeOfferings' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedNodeOfferingsMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedNodeOfferings', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ReservedNodeOfferingId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Specified offering does not exist.', 'class' => 'ReservedNodeOfferingNotFoundException', ), ), ), 'DescribeReservedNodes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedNodesMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeReservedNodes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ReservedNodeId' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxRecords' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'Marker' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified reserved compute node not found.', 'class' => 'ReservedNodeNotFoundException', ), ), ), 'DescribeResize' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ResizeProgressMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DescribeResize', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'A resize operation for the specified cluster is not found.', 'class' => 'ResizeNotFoundException', ), ), ), 'DisableLogging' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'LoggingStatus', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableLogging', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), ), ), 'DisableSnapshotCopy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DisableSnapshotCopy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The cluster already has cross-region snapshot copy disabled.', 'class' => 'SnapshotCopyAlreadyDisabledException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'EnableLogging' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'LoggingStatus', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableLogging', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'BucketName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'Could not find the specified S3 bucket.', 'class' => 'BucketNotFoundException', ), array( 'reason' => 'The cluster does not have read bucket or put object permissions on the S3 bucket specified when enabling logging.', 'class' => 'InsufficientS3BucketPolicyFaultException', ), array( 'reason' => 'The string specified for the logging S3 key prefix does not comply with the documented constraints.', 'class' => 'InvalidS3KeyPrefixFaultException', ), array( 'reason' => 'The S3 bucket name is invalid. For more information about naming rules, go to Bucket Restrictions and Limitations in the Amazon Simple Storage Service (S3) Developer Guide.', 'class' => 'InvalidS3BucketNameFaultException', ), ), ), 'EnableSnapshotCopy' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'EnableSnapshotCopy', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DestinationRegion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified options are incompatible.', 'class' => 'IncompatibleOrderableOptionsException', ), array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'Cross-region snapshot copy was temporarily disabled. Try your request again.', 'class' => 'CopyToRegionDisabledException', ), array( 'reason' => 'The cluster already has cross-region snapshot copy enabled.', 'class' => 'SnapshotCopyAlreadyEnabledException', ), array( 'reason' => 'The specified region is incorrect or does not exist.', 'class' => 'UnknownSnapshotCopyRegionException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'ModifyCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ClusterType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NodeType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NumberOfNodes' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ClusterSecurityGroups.member', 'items' => array( 'name' => 'ClusterSecurityGroupName', 'type' => 'string', ), ), 'VpcSecurityGroupIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'VpcSecurityGroupIds.member', 'items' => array( 'name' => 'VpcSecurityGroupId', 'type' => 'string', ), ), 'MasterUserPassword' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterParameterGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ClusterVersion' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'HsmClientCertificateIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The state of the cluster security group is not "available".', 'class' => 'InvalidClusterSecurityGroupStateException', ), array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The operation would exceed the number of nodes allotted to the account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'NumberOfNodesQuotaExceededException', ), array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), array( 'reason' => 'The number of nodes specified exceeds the allotted capacity of the cluster.', 'class' => 'InsufficientClusterCapacityException', ), array( 'reason' => 'An request option was specified that is not supported.', 'class' => 'UnsupportedOptionException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), ), ), 'ModifyClusterParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyClusterParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Parameters' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), array( 'reason' => 'The cluster parameter group action can not be completed because another task is in progress that involves the parameter group. Wait a few moments and try the operation again.', 'class' => 'InvalidClusterParameterGroupStateException', ), ), ), 'ModifyClusterSubnetGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSubnetGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyClusterSubnetGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSubnetGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Description' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SubnetIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SubnetIds.member', 'items' => array( 'name' => 'SubnetIdentifier', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), array( 'reason' => 'The request would result in user exceeding the allowed number of subnets in a cluster subnet groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterSubnetQuotaExceededException', ), array( 'reason' => 'A specified subnet is already in use by another cluster.', 'class' => 'SubnetAlreadyInUseException', ), array( 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'ModifyEventSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EventSubscriptionWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifyEventSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SubscriptionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'SourceIds' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SourceIds.member', 'items' => array( 'name' => 'SourceId', 'type' => 'string', ), ), 'EventCategories' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'EventCategories.member', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', ), ), 'Severity' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Enabled' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'An Amazon Redshift event notification subscription with the specified name does not exist.', 'class' => 'SubscriptionNotFoundException', ), array( 'reason' => 'Amazon SNS has responded that there is a problem with the specified Amazon SNS topic.', 'class' => 'SNSInvalidTopicException', ), array( 'reason' => 'You do not have permission to publish to the specified Amazon SNS topic.', 'class' => 'SNSNoAuthorizationException', ), array( 'reason' => 'An Amazon SNS topic with the specified Amazon Resource Name (ARN) does not exist.', 'class' => 'SNSTopicArnNotFoundException', ), array( 'reason' => 'An Amazon Redshift event with the specified event ID does not exist.', 'class' => 'SubscriptionEventIdNotFoundException', ), array( 'reason' => 'The value specified for the event category was not one of the allowed values, or it specified a category that does not apply to the specified source type. The allowed values are Configuration, Management, Monitoring, and Security.', 'class' => 'SubscriptionCategoryNotFoundException', ), array( 'reason' => 'The value specified for the event severity was not one of the allowed values, or it specified a severity that does not apply to the specified source type. The allowed values are ERROR and INFO.', 'class' => 'SubscriptionSeverityNotFoundException', ), array( 'reason' => 'The specified Amazon Redshift event source could not be found.', 'class' => 'SourceNotFoundException', ), ), ), 'ModifySnapshotCopyRetentionPeriod' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ModifySnapshotCopyRetentionPeriod', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'RetentionPeriod' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'Cross-region snapshot copy was temporarily disabled. Try your request again.', 'class' => 'SnapshotCopyDisabledException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), ), ), 'PurchaseReservedNodeOffering' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReservedNodeWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PurchaseReservedNodeOffering', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ReservedNodeOfferingId' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NodeCount' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Specified offering does not exist.', 'class' => 'ReservedNodeOfferingNotFoundException', ), array( 'reason' => 'User already has a reservation with the given identifier.', 'class' => 'ReservedNodeAlreadyExistsException', ), array( 'reason' => 'Request would exceed the user\'s compute node quota. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ReservedNodeQuotaExceededException', ), ), ), 'RebootCluster' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RebootCluster', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), ), ), 'ResetClusterParameterGroup' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterParameterGroupNameMessage', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ResetClusterParameterGroup', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ParameterGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ResetAllParameters' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'Parameters' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Parameters.member', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The cluster parameter group action can not be completed because another task is in progress that involves the parameter group. Wait a few moments and try the operation again.', 'class' => 'InvalidClusterParameterGroupStateException', ), array( 'reason' => 'The parameter group name does not refer to an existing parameter group.', 'class' => 'ClusterParameterGroupNotFoundException', ), ), ), 'RestoreFromClusterSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RestoreFromClusterSnapshot', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Port' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'AvailabilityZone' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'ClusterSubnetGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'PubliclyAccessible' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), 'OwnerAccount' => array( 'type' => 'string', 'location' => 'aws.query', ), 'HsmClientCertificateIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ElasticIp' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The owner of the specified snapshot has not authorized your account to access the snapshot.', 'class' => 'AccessToSnapshotDeniedException', ), array( 'reason' => 'The account already has a cluster with the given identifier.', 'class' => 'ClusterAlreadyExistsException', ), array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), array( 'reason' => 'The request would exceed the allowed number of cluster instances for this account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'ClusterQuotaExceededException', ), array( 'reason' => 'The number of nodes specified exceeds the allotted capacity of the cluster.', 'class' => 'InsufficientClusterCapacityException', ), array( 'reason' => 'The state of the cluster snapshot is not "available", or other accounts are authorized to access the snapshot.', 'class' => 'InvalidClusterSnapshotStateException', ), array( 'reason' => 'The restore is invalid.', 'class' => 'InvalidRestoreException', ), array( 'reason' => 'The operation would exceed the number of nodes allotted to the account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', 'class' => 'NumberOfNodesQuotaExceededException', ), array( 'reason' => 'The operation would exceed the number of nodes allowed for a cluster.', 'class' => 'NumberOfNodesPerClusterLimitExceededException', ), array( 'reason' => 'The cluster subnet group does not cover all Availability Zones.', 'class' => 'InvalidVPCNetworkStateException', ), array( 'reason' => 'The cluster subnet group cannot be deleted because it is in use.', 'class' => 'InvalidClusterSubnetGroupStateException', ), array( 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', 'class' => 'InvalidSubnetException', ), array( 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', 'class' => 'ClusterSubnetGroupNotFoundException', ), array( 'reason' => 'Your account is not authorized to perform the requested operation.', 'class' => 'UnauthorizedOperationException', ), array( 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', 'class' => 'HsmClientCertificateNotFoundException', ), array( 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', 'class' => 'HsmConfigurationNotFoundException', ), array( 'reason' => 'The Elastic IP (EIP) is invalid or cannot be found.', 'class' => 'InvalidElasticIpException', ), ), ), 'RevokeClusterSecurityGroupIngress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterSecurityGroupWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeClusterSecurityGroupIngress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterSecurityGroupName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CIDRIP' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupName' => array( 'type' => 'string', 'location' => 'aws.query', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', 'class' => 'ClusterSecurityGroupNotFoundException', ), array( 'reason' => 'The specified CIDR IP range or EC2 security group is not authorized for the specified cluster security group.', 'class' => 'AuthorizationNotFoundException', ), array( 'reason' => 'The state of the cluster security group is not "available".', 'class' => 'InvalidClusterSecurityGroupStateException', ), ), ), 'RevokeSnapshotAccess' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SnapshotWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RevokeSnapshotAccess', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'SnapshotIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnapshotClusterIdentifier' => array( 'type' => 'string', 'location' => 'aws.query', ), 'AccountWithRestoreAccess' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The owner of the specified snapshot has not authorized your account to access the snapshot.', 'class' => 'AccessToSnapshotDeniedException', ), array( 'reason' => 'The specified CIDR IP range or EC2 security group is not authorized for the specified cluster security group.', 'class' => 'AuthorizationNotFoundException', ), array( 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', 'class' => 'ClusterSnapshotNotFoundException', ), ), ), 'RotateEncryptionKey' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ClusterWrapper', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RotateEncryptionKey', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-12-01', ), 'ClusterIdentifier' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', 'class' => 'ClusterNotFoundException', ), array( 'reason' => 'The specified cluster is not in the available state.', 'class' => 'InvalidClusterStateException', ), ), ), ), 'models' => array( 'ClusterSecurityGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ClusterSecurityGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ClusterSecurityGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), 'IPRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IPRange', 'type' => 'object', 'sentAs' => 'IPRange', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CIDRIP' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'SnapshotWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Snapshot' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'SnapshotIdentifier' => array( 'type' => 'string', ), 'ClusterIdentifier' => array( 'type' => 'string', ), 'SnapshotCreateTime' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'ClusterCreateTime' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'ClusterVersion' => array( 'type' => 'string', ), 'SnapshotType' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'DBName' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Encrypted' => array( 'type' => 'boolean', ), 'EncryptedWithHSM' => array( 'type' => 'boolean', ), 'AccountsWithRestoreAccess' => array( 'type' => 'array', 'items' => array( 'name' => 'AccountWithRestoreAccess', 'type' => 'object', 'sentAs' => 'AccountWithRestoreAccess', 'properties' => array( 'AccountId' => array( 'type' => 'string', ), ), ), ), 'OwnerAccount' => array( 'type' => 'string', ), 'TotalBackupSizeInMegaBytes' => array( 'type' => 'numeric', ), 'ActualIncrementalBackupSizeInMegaBytes' => array( 'type' => 'numeric', ), 'BackupProgressInMegaBytes' => array( 'type' => 'numeric', ), 'CurrentBackupRateInMegaBytesPerSecond' => array( 'type' => 'numeric', ), 'EstimatedSecondsToCompletion' => array( 'type' => 'numeric', ), 'ElapsedTimeInSeconds' => array( 'type' => 'numeric', ), 'SourceRegion' => array( 'type' => 'string', ), ), ), ), ), 'ClusterWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Cluster' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ClusterIdentifier' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'ClusterStatus' => array( 'type' => 'string', ), 'ModifyStatus' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'DBName' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ClusterCreateTime' => array( 'type' => 'string', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterSecurityGroup', 'type' => 'object', 'sentAs' => 'ClusterSecurityGroup', 'properties' => array( 'ClusterSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroup', 'type' => 'object', 'sentAs' => 'VpcSecurityGroup', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'ClusterParameterGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterParameterGroup', 'type' => 'object', 'sentAs' => 'ClusterParameterGroup', 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), ), ), ), 'ClusterSubnetGroupName' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'MasterUserPassword' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'ClusterType' => array( 'type' => 'string', ), 'ClusterVersion' => array( 'type' => 'string', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', ), ), ), 'ClusterVersion' => array( 'type' => 'string', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'PubliclyAccessible' => array( 'type' => 'boolean', ), 'Encrypted' => array( 'type' => 'boolean', ), 'RestoreStatus' => array( 'type' => 'object', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CurrentRestoreRateInMegaBytesPerSecond' => array( 'type' => 'numeric', ), 'SnapshotSizeInMegaBytes' => array( 'type' => 'numeric', ), 'ProgressInMegaBytes' => array( 'type' => 'numeric', ), 'ElapsedTimeInSeconds' => array( 'type' => 'numeric', ), 'EstimatedTimeToCompletionInSeconds' => array( 'type' => 'numeric', ), ), ), 'HsmStatus' => array( 'type' => 'object', 'properties' => array( 'HsmClientCertificateIdentifier' => array( 'type' => 'string', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), 'ClusterSnapshotCopyStatus' => array( 'type' => 'object', 'properties' => array( 'DestinationRegion' => array( 'type' => 'string', ), 'RetentionPeriod' => array( 'type' => 'numeric', ), ), ), 'ClusterPublicKey' => array( 'type' => 'string', ), 'ClusterNodes' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterNode', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'NodeRole' => array( 'type' => 'string', ), 'PrivateIPAddress' => array( 'type' => 'string', ), 'PublicIPAddress' => array( 'type' => 'string', ), ), ), ), 'ElasticIpStatus' => array( 'type' => 'object', 'properties' => array( 'ElasticIp' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), ), ), ), 'ClusterParameterGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ClusterParameterGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', ), 'ParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), 'ClusterSubnetGroupWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ClusterSubnetGroup' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ClusterSubnetGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EventSubscriptionWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EventSubscription' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'CustomerAwsId' => array( 'type' => 'string', ), 'CustSubscriptionId' => array( 'type' => 'string', ), 'SnsTopicArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubscriptionCreationTime' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'SourceIdsList' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceId', 'type' => 'string', 'sentAs' => 'SourceId', ), ), 'EventCategoriesList' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Severity' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), 'HsmClientCertificateWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HsmClientCertificate' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'HsmClientCertificateIdentifier' => array( 'type' => 'string', ), 'HsmClientCertificatePublicKey' => array( 'type' => 'string', ), ), ), ), ), 'HsmConfigurationWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HsmConfiguration' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'HsmConfigurationIdentifier' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'HsmIpAddress' => array( 'type' => 'string', ), 'HsmPartitionName' => array( 'type' => 'string', ), ), ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ClusterParameterGroupsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ParameterGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ClusterParameterGroup', 'type' => 'object', 'sentAs' => 'ClusterParameterGroup', 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', ), 'ParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'ClusterParameterGroupDetails' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Parameters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ClusterSecurityGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ClusterSecurityGroup', 'type' => 'object', 'sentAs' => 'ClusterSecurityGroup', 'properties' => array( 'ClusterSecurityGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'EC2SecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'EC2SecurityGroup', 'type' => 'object', 'sentAs' => 'EC2SecurityGroup', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'EC2SecurityGroupName' => array( 'type' => 'string', ), 'EC2SecurityGroupOwnerId' => array( 'type' => 'string', ), ), ), ), 'IPRanges' => array( 'type' => 'array', 'items' => array( 'name' => 'IPRange', 'type' => 'object', 'sentAs' => 'IPRange', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CIDRIP' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'SnapshotMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Snapshots' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Snapshot', 'type' => 'object', 'sentAs' => 'Snapshot', 'properties' => array( 'SnapshotIdentifier' => array( 'type' => 'string', ), 'ClusterIdentifier' => array( 'type' => 'string', ), 'SnapshotCreateTime' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'ClusterCreateTime' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'ClusterVersion' => array( 'type' => 'string', ), 'SnapshotType' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'DBName' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'Encrypted' => array( 'type' => 'boolean', ), 'EncryptedWithHSM' => array( 'type' => 'boolean', ), 'AccountsWithRestoreAccess' => array( 'type' => 'array', 'items' => array( 'name' => 'AccountWithRestoreAccess', 'type' => 'object', 'sentAs' => 'AccountWithRestoreAccess', 'properties' => array( 'AccountId' => array( 'type' => 'string', ), ), ), ), 'OwnerAccount' => array( 'type' => 'string', ), 'TotalBackupSizeInMegaBytes' => array( 'type' => 'numeric', ), 'ActualIncrementalBackupSizeInMegaBytes' => array( 'type' => 'numeric', ), 'BackupProgressInMegaBytes' => array( 'type' => 'numeric', ), 'CurrentBackupRateInMegaBytesPerSecond' => array( 'type' => 'numeric', ), 'EstimatedSecondsToCompletion' => array( 'type' => 'numeric', ), 'ElapsedTimeInSeconds' => array( 'type' => 'numeric', ), 'SourceRegion' => array( 'type' => 'string', ), ), ), ), ), ), 'ClusterSubnetGroupMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ClusterSubnetGroups' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ClusterSubnetGroup', 'type' => 'object', 'sentAs' => 'ClusterSubnetGroup', 'properties' => array( 'ClusterSubnetGroupName' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'SubnetGroupStatus' => array( 'type' => 'string', ), 'Subnets' => array( 'type' => 'array', 'items' => array( 'name' => 'Subnet', 'type' => 'object', 'sentAs' => 'Subnet', 'properties' => array( 'SubnetIdentifier' => array( 'type' => 'string', ), 'SubnetAvailabilityZone' => array( 'type' => 'object', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), 'SubnetStatus' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ClusterVersionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ClusterVersions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ClusterVersion', 'type' => 'object', 'sentAs' => 'ClusterVersion', 'properties' => array( 'ClusterVersion' => array( 'type' => 'string', ), 'ClusterParameterGroupFamily' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), ), ), ), ), ), 'ClustersMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Clusters' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Cluster', 'type' => 'object', 'sentAs' => 'Cluster', 'properties' => array( 'ClusterIdentifier' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'ClusterStatus' => array( 'type' => 'string', ), 'ModifyStatus' => array( 'type' => 'string', ), 'MasterUsername' => array( 'type' => 'string', ), 'DBName' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'object', 'properties' => array( 'Address' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), ), ), 'ClusterCreateTime' => array( 'type' => 'string', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', ), 'ClusterSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterSecurityGroup', 'type' => 'object', 'sentAs' => 'ClusterSecurityGroup', 'properties' => array( 'ClusterSecurityGroupName' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'VpcSecurityGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'VpcSecurityGroup', 'type' => 'object', 'sentAs' => 'VpcSecurityGroup', 'properties' => array( 'VpcSecurityGroupId' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), 'ClusterParameterGroups' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterParameterGroup', 'type' => 'object', 'sentAs' => 'ClusterParameterGroup', 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', ), 'ParameterApplyStatus' => array( 'type' => 'string', ), ), ), ), 'ClusterSubnetGroupName' => array( 'type' => 'string', ), 'VpcId' => array( 'type' => 'string', ), 'AvailabilityZone' => array( 'type' => 'string', ), 'PreferredMaintenanceWindow' => array( 'type' => 'string', ), 'PendingModifiedValues' => array( 'type' => 'object', 'properties' => array( 'MasterUserPassword' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'ClusterType' => array( 'type' => 'string', ), 'ClusterVersion' => array( 'type' => 'string', ), 'AutomatedSnapshotRetentionPeriod' => array( 'type' => 'numeric', ), ), ), 'ClusterVersion' => array( 'type' => 'string', ), 'AllowVersionUpgrade' => array( 'type' => 'boolean', ), 'NumberOfNodes' => array( 'type' => 'numeric', ), 'PubliclyAccessible' => array( 'type' => 'boolean', ), 'Encrypted' => array( 'type' => 'boolean', ), 'RestoreStatus' => array( 'type' => 'object', 'properties' => array( 'Status' => array( 'type' => 'string', ), 'CurrentRestoreRateInMegaBytesPerSecond' => array( 'type' => 'numeric', ), 'SnapshotSizeInMegaBytes' => array( 'type' => 'numeric', ), 'ProgressInMegaBytes' => array( 'type' => 'numeric', ), 'ElapsedTimeInSeconds' => array( 'type' => 'numeric', ), 'EstimatedTimeToCompletionInSeconds' => array( 'type' => 'numeric', ), ), ), 'HsmStatus' => array( 'type' => 'object', 'properties' => array( 'HsmClientCertificateIdentifier' => array( 'type' => 'string', ), 'HsmConfigurationIdentifier' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), 'ClusterSnapshotCopyStatus' => array( 'type' => 'object', 'properties' => array( 'DestinationRegion' => array( 'type' => 'string', ), 'RetentionPeriod' => array( 'type' => 'numeric', ), ), ), 'ClusterPublicKey' => array( 'type' => 'string', ), 'ClusterNodes' => array( 'type' => 'array', 'items' => array( 'name' => 'ClusterNode', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'NodeRole' => array( 'type' => 'string', ), 'PrivateIPAddress' => array( 'type' => 'string', ), 'PublicIPAddress' => array( 'type' => 'string', ), ), ), ), 'ElasticIpStatus' => array( 'type' => 'object', 'properties' => array( 'ElasticIp' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'DefaultClusterParametersWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DefaultClusterParameters' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ParameterGroupFamily' => array( 'type' => 'string', ), 'Marker' => array( 'type' => 'string', ), 'Parameters' => array( 'type' => 'array', 'items' => array( 'name' => 'Parameter', 'type' => 'object', 'sentAs' => 'Parameter', 'properties' => array( 'ParameterName' => array( 'type' => 'string', ), 'ParameterValue' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'Source' => array( 'type' => 'string', ), 'DataType' => array( 'type' => 'string', ), 'AllowedValues' => array( 'type' => 'string', ), 'IsModifiable' => array( 'type' => 'boolean', ), 'MinimumEngineVersion' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'EventCategoriesMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EventCategoriesMapList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventCategoriesMap', 'type' => 'object', 'sentAs' => 'EventCategoriesMap', 'properties' => array( 'SourceType' => array( 'type' => 'string', ), 'Events' => array( 'type' => 'array', 'items' => array( 'name' => 'EventInfoMap', 'type' => 'object', 'sentAs' => 'EventInfoMap', 'properties' => array( 'EventId' => array( 'type' => 'string', ), 'EventCategories' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'EventDescription' => array( 'type' => 'string', ), 'Severity' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'EventSubscriptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'EventSubscriptionsList' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'EventSubscription', 'type' => 'object', 'sentAs' => 'EventSubscription', 'properties' => array( 'CustomerAwsId' => array( 'type' => 'string', ), 'CustSubscriptionId' => array( 'type' => 'string', ), 'SnsTopicArn' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubscriptionCreationTime' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'SourceIdsList' => array( 'type' => 'array', 'items' => array( 'name' => 'SourceId', 'type' => 'string', 'sentAs' => 'SourceId', ), ), 'EventCategoriesList' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Severity' => array( 'type' => 'string', ), 'Enabled' => array( 'type' => 'boolean', ), ), ), ), ), ), 'EventsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'Events' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Event', 'type' => 'object', 'sentAs' => 'Event', 'properties' => array( 'SourceIdentifier' => array( 'type' => 'string', ), 'SourceType' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'EventCategories' => array( 'type' => 'array', 'items' => array( 'name' => 'EventCategory', 'type' => 'string', 'sentAs' => 'EventCategory', ), ), 'Severity' => array( 'type' => 'string', ), 'Date' => array( 'type' => 'string', ), 'EventId' => array( 'type' => 'string', ), ), ), ), ), ), 'HsmClientCertificateMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'HsmClientCertificates' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'HsmClientCertificate', 'type' => 'object', 'sentAs' => 'HsmClientCertificate', 'properties' => array( 'HsmClientCertificateIdentifier' => array( 'type' => 'string', ), 'HsmClientCertificatePublicKey' => array( 'type' => 'string', ), ), ), ), ), ), 'HsmConfigurationMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'HsmConfigurations' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'HsmConfiguration', 'type' => 'object', 'sentAs' => 'HsmConfiguration', 'properties' => array( 'HsmConfigurationIdentifier' => array( 'type' => 'string', ), 'Description' => array( 'type' => 'string', ), 'HsmIpAddress' => array( 'type' => 'string', ), 'HsmPartitionName' => array( 'type' => 'string', ), ), ), ), ), ), 'LoggingStatus' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoggingEnabled' => array( 'type' => 'boolean', 'location' => 'xml', ), 'BucketName' => array( 'type' => 'string', 'location' => 'xml', ), 'S3KeyPrefix' => array( 'type' => 'string', 'location' => 'xml', ), 'LastSuccessfulDeliveryTime' => array( 'type' => 'string', 'location' => 'xml', ), 'LastFailureTime' => array( 'type' => 'string', 'location' => 'xml', ), 'LastFailureMessage' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'OrderableClusterOptionsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'OrderableClusterOptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'OrderableClusterOption', 'type' => 'object', 'sentAs' => 'OrderableClusterOption', 'properties' => array( 'ClusterVersion' => array( 'type' => 'string', ), 'ClusterType' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'AvailabilityZones' => array( 'type' => 'array', 'items' => array( 'name' => 'AvailabilityZone', 'type' => 'object', 'sentAs' => 'AvailabilityZone', 'properties' => array( 'Name' => array( 'type' => 'string', ), ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedNodeOfferingsMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedNodeOfferings' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedNodeOffering', 'type' => 'object', 'sentAs' => 'ReservedNodeOffering', 'properties' => array( 'ReservedNodeOfferingId' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ReservedNodesMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'ReservedNodes' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ReservedNode', 'type' => 'object', 'sentAs' => 'ReservedNode', 'properties' => array( 'ReservedNodeId' => array( 'type' => 'string', ), 'ReservedNodeOfferingId' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'NodeCount' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'ResizeProgressMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TargetNodeType' => array( 'type' => 'string', 'location' => 'xml', ), 'TargetNumberOfNodes' => array( 'type' => 'numeric', 'location' => 'xml', ), 'TargetClusterType' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'ImportTablesCompleted' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'String', 'type' => 'string', 'sentAs' => 'member', ), ), 'ImportTablesInProgress' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'String', 'type' => 'string', 'sentAs' => 'member', ), ), 'ImportTablesNotStarted' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'String', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'ClusterParameterGroupNameMessage' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ParameterGroupName' => array( 'type' => 'string', 'location' => 'xml', ), 'ParameterGroupStatus' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ReservedNodeWrapper' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ReservedNode' => array( 'type' => 'object', 'location' => 'xml', 'data' => array( 'wrapper' => true, ), 'properties' => array( 'ReservedNodeId' => array( 'type' => 'string', ), 'ReservedNodeOfferingId' => array( 'type' => 'string', ), 'NodeType' => array( 'type' => 'string', ), 'StartTime' => array( 'type' => 'string', ), 'Duration' => array( 'type' => 'numeric', ), 'FixedPrice' => array( 'type' => 'numeric', ), 'UsagePrice' => array( 'type' => 'numeric', ), 'CurrencyCode' => array( 'type' => 'string', ), 'NodeCount' => array( 'type' => 'numeric', ), 'State' => array( 'type' => 'string', ), 'OfferingType' => array( 'type' => 'string', ), 'RecurringCharges' => array( 'type' => 'array', 'items' => array( 'name' => 'RecurringCharge', 'type' => 'object', 'sentAs' => 'RecurringCharge', 'properties' => array( 'RecurringChargeAmount' => array( 'type' => 'numeric', ), 'RecurringChargeFrequency' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeClusterParameterGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ParameterGroups', ), 'DescribeClusterParameters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Parameters', ), 'DescribeClusterSecurityGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ClusterSecurityGroups', ), 'DescribeClusterSnapshots' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Snapshots', ), 'DescribeClusterSubnetGroups' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ClusterSubnetGroups', ), 'DescribeClusterVersions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ClusterVersions', ), 'DescribeClusters' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Clusters', ), 'DescribeDefaultClusterParameters' => array( 'token_param' => 'Marker', 'limit_key' => 'MaxRecords', ), 'DescribeEventSubscriptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'EventSubscriptionsList', ), 'DescribeEvents' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'Events', ), 'DescribeHsmClientCertificates' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'HsmClientCertificates', ), 'DescribeHsmConfigurations' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'HsmConfigurations', ), 'DescribeOrderableClusterOptions' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'OrderableClusterOptions', ), 'DescribeReservedNodeOfferings' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedNodeOfferings', ), 'DescribeReservedNodes' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'MaxRecords', 'result_key' => 'ReservedNodes', ), ), ), 'waiters' => array( '__default__' => array( 'acceptor.type' => 'output', ), '__ClusterState' => array( 'interval' => 60, 'max_attempts' => 30, 'operation' => 'DescribeClusters', 'acceptor.path' => 'Clusters/*/ClusterStatus', ), 'ClusterAvailable' => array( 'extends' => '__ClusterState', 'success.value' => 'available', 'failure.value' => array( 'deleting', ), 'ignore_errors' => array( 'ClusterNotFound', ), ), 'ClusterDeleted' => array( 'extends' => '__ClusterState', 'success.type' => 'error', 'success.value' => 'ClusterNotFound', 'failure.value' => array( 'creating', 'rebooting', ), ), 'SnapshotAvailable' => array( 'interval' => 15, 'max_attempts' => 20, 'operation' => 'DescribeClusterSnapshots', 'acceptor.path' => 'Snapshots/*/Status', 'success.value' => 'available', 'failure.value' => array( 'failed', 'deleted', ), ), ), ); '2012-12-12', 'endpointPrefix' => 'route53', 'serviceFullName' => 'Amazon Route 53', 'serviceAbbreviation' => 'Route 53', 'serviceType' => 'rest-xml', 'globalEndpoint' => 'route53.amazonaws.com', 'signatureVersion' => 'v3https', 'namespace' => 'Route53', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'route53.amazonaws.com', ), ), 'operations' => array( 'ChangeResourceRecordSets' => array( 'httpMethod' => 'POST', 'uri' => '/2012-12-12/hostedzone/{HostedZoneId}/rrset/', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ChangeResourceRecordSetsResponse', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'ChangeResourceRecordSetsRequest', 'namespaces' => array( 'https://route53.amazonaws.com/doc/2012-12-12/', ), ), ), 'parameters' => array( 'HostedZoneId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'ChangeBatch' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Comment' => array( 'type' => 'string', 'maxLength' => 256, ), 'Changes' => array( 'required' => true, 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'Change', 'type' => 'object', 'properties' => array( 'Action' => array( 'required' => true, 'type' => 'string', ), 'ResourceRecordSet' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'maxLength' => 1024, ), 'Type' => array( 'required' => true, 'type' => 'string', ), 'SetIdentifier' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 128, ), 'Weight' => array( 'type' => 'numeric', 'maximum' => 255, ), 'Region' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), 'Failover' => array( 'type' => 'string', ), 'TTL' => array( 'type' => 'numeric', 'maximum' => 2147483647, ), 'ResourceRecords' => array( 'type' => 'array', 'minItems' => 1, 'items' => array( 'name' => 'ResourceRecord', 'type' => 'object', 'properties' => array( 'Value' => array( 'required' => true, 'type' => 'string', 'maxLength' => 4000, ), ), ), ), 'AliasTarget' => array( 'type' => 'object', 'properties' => array( 'HostedZoneId' => array( 'required' => true, 'type' => 'string', 'maxLength' => 32, ), 'DNSName' => array( 'required' => true, 'type' => 'string', 'maxLength' => 1024, ), 'EvaluateTargetHealth' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), 'HealthCheckId' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), ), ), ), ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchHostedZoneException', ), array( 'reason' => 'The health check you are trying to get or delete does not exist.', 'class' => 'NoSuchHealthCheckException', ), array( 'reason' => 'This error contains a list of one or more error messages. Each error message indicates one error in the change batch. For more information, see Example InvalidChangeBatch Errors.', 'class' => 'InvalidChangeBatchException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), array( 'reason' => 'The request was rejected because Route 53 was still processing a prior request.', 'class' => 'PriorRequestNotCompleteException', ), ), ), 'CreateHealthCheck' => array( 'httpMethod' => 'POST', 'uri' => '/2012-12-12/healthcheck', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateHealthCheckResponse', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'CreateHealthCheckRequest', 'namespaces' => array( 'https://route53.amazonaws.com/doc/2012-12-12/', ), ), ), 'parameters' => array( 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', 'minLength' => 1, 'maxLength' => 64, ), 'HealthCheckConfig' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'IPAddress' => array( 'required' => true, 'type' => 'string', 'maxLength' => 15, ), 'Port' => array( 'type' => 'numeric', 'minimum' => 1, 'maximum' => 65535, ), 'Type' => array( 'required' => true, 'type' => 'string', ), 'ResourcePath' => array( 'type' => 'string', 'maxLength' => 255, ), 'FullyQualifiedDomainName' => array( 'type' => 'string', 'maxLength' => 255, ), ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'TooManyHealthChecksException', ), array( 'reason' => 'The health check you are trying to create already exists. Route 53 returns this error when a health check has already been created with the specified CallerReference.', 'class' => 'HealthCheckAlreadyExistsException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'CreateHostedZone' => array( 'httpMethod' => 'POST', 'uri' => '/2012-12-12/hostedzone', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'CreateHostedZoneResponse', 'responseType' => 'model', 'data' => array( 'xmlRoot' => array( 'name' => 'CreateHostedZoneRequest', 'namespaces' => array( 'https://route53.amazonaws.com/doc/2012-12-12/', ), ), ), 'parameters' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', 'maxLength' => 1024, ), 'CallerReference' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', 'minLength' => 1, 'maxLength' => 128, ), 'HostedZoneConfig' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Comment' => array( 'type' => 'string', 'maxLength' => 256, ), ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'This error indicates that the specified domain name is not valid.', 'class' => 'InvalidDomainNameException', ), array( 'reason' => 'The hosted zone you are trying to create already exists. Route 53 returns this error when a hosted zone has already been created with the specified CallerReference.', 'class' => 'HostedZoneAlreadyExistsException', ), array( 'reason' => 'This error indicates that you\'ve reached the maximum number of hosted zones that can be created for the current AWS account. You can request an increase to the limit on the Contact Us page.', 'class' => 'TooManyHostedZonesException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), array( 'reason' => 'Route 53 allows some duplicate domain names, but there is a maximum number of duplicate names. This error indicates that you have reached that maximum. If you want to create another hosted zone with the same name and Route 53 generates this error, you can request an increase to the limit on the Contact Us page.', 'class' => 'DelegationSetNotAvailableException', ), ), ), 'DeleteHealthCheck' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-12-12/healthcheck/{HealthCheckId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteHealthCheckResponse', 'responseType' => 'model', 'parameters' => array( 'HealthCheckId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'The health check you are trying to get or delete does not exist.', 'class' => 'NoSuchHealthCheckException', ), array( 'reason' => 'There are resource records associated with this health check. Before you can delete the health check, you must disassociate it from the resource record sets.', 'class' => 'HealthCheckInUseException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'DeleteHostedZone' => array( 'httpMethod' => 'DELETE', 'uri' => '/2012-12-12/hostedzone/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'DeleteHostedZoneResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchHostedZoneException', ), array( 'reason' => 'The hosted zone contains resource record sets in addition to the default NS and SOA resource record sets. Before you can delete the hosted zone, you must delete the additional resource record sets.', 'class' => 'HostedZoneNotEmptyException', ), array( 'reason' => 'The request was rejected because Route 53 was still processing a prior request.', 'class' => 'PriorRequestNotCompleteException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'GetChange' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/change/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetChangeResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchChangeException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'GetHealthCheck' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/healthcheck/{HealthCheckId}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetHealthCheckResponse', 'responseType' => 'model', 'parameters' => array( 'HealthCheckId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 64, ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The health check you are trying to get or delete does not exist.', 'class' => 'NoSuchHealthCheckException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'GetHostedZone' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/hostedzone/{Id}', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'GetHostedZoneResponse', 'responseType' => 'model', 'parameters' => array( 'Id' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchHostedZoneException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'ListHealthChecks' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/healthcheck', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListHealthChecksResponse', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'marker', 'maxLength' => 64, ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'maxitems', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'ListHostedZones' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/hostedzone', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListHostedZonesResponse', 'responseType' => 'model', 'parameters' => array( 'Marker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'marker', 'maxLength' => 64, ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'maxitems', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), 'ListResourceRecordSets' => array( 'httpMethod' => 'GET', 'uri' => '/2012-12-12/hostedzone/{HostedZoneId}/rrset', 'class' => 'Guzzle\\Service\\Command\\OperationCommand', 'responseClass' => 'ListResourceRecordSetsResponse', 'responseType' => 'model', 'parameters' => array( 'HostedZoneId' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'maxLength' => 32, 'filters' => array( 'Aws\\Route53\\Route53Client::cleanId', ), ), 'StartRecordName' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'name', 'maxLength' => 1024, ), 'StartRecordType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'type', ), 'StartRecordIdentifier' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'identifier', 'minLength' => 1, 'maxLength' => 128, ), 'MaxItems' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'maxitems', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'class' => 'NoSuchHostedZoneException', ), array( 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', 'class' => 'InvalidInputException', ), ), ), ), 'models' => array( 'ChangeResourceRecordSetsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ChangeInfo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubmittedAt' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateHealthCheckResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HealthCheck' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'HealthCheckConfig' => array( 'type' => 'object', 'properties' => array( 'IPAddress' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'Type' => array( 'type' => 'string', ), 'ResourcePath' => array( 'type' => 'string', ), 'FullyQualifiedDomainName' => array( 'type' => 'string', ), ), ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateHostedZoneResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HostedZone' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'Config' => array( 'type' => 'object', 'properties' => array( 'Comment' => array( 'type' => 'string', ), ), ), 'ResourceRecordSetCount' => array( 'type' => 'numeric', ), ), ), 'ChangeInfo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubmittedAt' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'DelegationSet' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'NameServers' => array( 'type' => 'array', 'items' => array( 'name' => 'NameServer', 'type' => 'string', 'sentAs' => 'NameServer', ), ), ), ), 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteHealthCheckResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteHostedZoneResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ChangeInfo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubmittedAt' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetChangeResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ChangeInfo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'SubmittedAt' => array( 'type' => 'string', ), 'Comment' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetHealthCheckResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HealthCheck' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'HealthCheckConfig' => array( 'type' => 'object', 'properties' => array( 'IPAddress' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'Type' => array( 'type' => 'string', ), 'ResourcePath' => array( 'type' => 'string', ), 'FullyQualifiedDomainName' => array( 'type' => 'string', ), ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetHostedZoneResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HostedZone' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'Config' => array( 'type' => 'object', 'properties' => array( 'Comment' => array( 'type' => 'string', ), ), ), 'ResourceRecordSetCount' => array( 'type' => 'numeric', ), ), ), 'DelegationSet' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'NameServers' => array( 'type' => 'array', 'items' => array( 'name' => 'NameServer', 'type' => 'string', 'sentAs' => 'NameServer', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListHealthChecksResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HealthChecks' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'HealthCheck', 'type' => 'object', 'sentAs' => 'HealthCheck', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'HealthCheckConfig' => array( 'type' => 'object', 'properties' => array( 'IPAddress' => array( 'type' => 'string', ), 'Port' => array( 'type' => 'numeric', ), 'Type' => array( 'type' => 'string', ), 'ResourcePath' => array( 'type' => 'string', ), 'FullyQualifiedDomainName' => array( 'type' => 'string', ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListHostedZonesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'HostedZones' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'HostedZone', 'type' => 'object', 'sentAs' => 'HostedZone', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), 'CallerReference' => array( 'type' => 'string', ), 'Config' => array( 'type' => 'object', 'properties' => array( 'Comment' => array( 'type' => 'string', ), ), ), 'ResourceRecordSetCount' => array( 'type' => 'numeric', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListResourceRecordSetsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ResourceRecordSets' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'ResourceRecordSet', 'type' => 'object', 'sentAs' => 'ResourceRecordSet', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', ), 'SetIdentifier' => array( 'type' => 'string', ), 'Weight' => array( 'type' => 'numeric', ), 'Region' => array( 'type' => 'string', ), 'Failover' => array( 'type' => 'string', ), 'TTL' => array( 'type' => 'numeric', ), 'ResourceRecords' => array( 'type' => 'array', 'items' => array( 'name' => 'ResourceRecord', 'type' => 'object', 'sentAs' => 'ResourceRecord', 'properties' => array( 'Value' => array( 'type' => 'string', ), ), ), ), 'AliasTarget' => array( 'type' => 'object', 'properties' => array( 'HostedZoneId' => array( 'type' => 'string', ), 'DNSName' => array( 'type' => 'string', ), 'EvaluateTargetHealth' => array( 'type' => 'boolean', ), ), ), 'HealthCheckId' => array( 'type' => 'string', ), ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'NextRecordName' => array( 'type' => 'string', 'location' => 'xml', ), 'NextRecordType' => array( 'type' => 'string', 'location' => 'xml', ), 'NextRecordIdentifier' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxItems' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), ), 'iterators' => array( 'operations' => array( 'ListHealthChecks' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'HealthChecks', ), 'ListHostedZones' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'HostedZones', ), 'ListResourceRecordSets' => array( 'more_key' => 'IsTruncated', 'limit_key' => 'MaxItems', 'result_key' => 'ResourceRecordSets', 'token_param' => array( 'StartRecordName', 'StartRecordType', 'StartRecordIdentifier', ), 'token_key' => array( 'NextRecordName', 'NextRecordType', 'NextRecordIdentifier', ), ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/route53-%s.php' )) ->build(); } /** * Retrieves the server time from Route53. Can be useful for detecting and/or preventing clock skew. * * @return \DateTime The server time from Route53 * @link http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/RESTAuthentication.html#FetchingDate */ public function getServerTime() { try { $response = $this->get('https://route53.amazonaws.com/date')->send(); } catch (ServiceResponseException $e) { $response = $e->getResponse(); } $serverTime = trim($response->getHeader('Date', true)); $serverTime = \DateTime::createFromFormat(DateFormat::RFC1123, $serverTime); return $serverTime; } /** * Filter function used to remove ID prefixes. This is used automatically by the client so that Hosted Zone and * Change Record IDs can be specified with or without the prefix. * * @param string $id The ID value to clean * * @return string */ public static function cleanId($id) { return str_replace(array('/hostedzone/', '/change/'), '', $id); } } array('onCommandBeforePrepare', -255)); } /** * An event handler for constructing ACP definitions. * * @param Event $event The event to respond to. * * @throws InvalidArgumentException */ public function onCommandBeforePrepare(Event $event) { /** @var $command \Guzzle\Service\Command\AbstractCommand */ $command = $event['command']; $operation = $command->getOperation(); if ($operation->hasParam('ACP') && $command->hasKey('ACP')) { if ($acp = $command->get('ACP')) { // Ensure that the correct object was passed if (!($acp instanceof Acp)) { throw new InvalidArgumentException('ACP must be an instance of Aws\S3\Model\Acp'); } // Check if the user specified both an ACP and Grants if ($command->hasKey('Grants')) { throw new InvalidArgumentException( 'Use either the ACP parameter or the Grants parameter. Do not use both.' ); } // Add the correct headers/body based parameters to the command if ($operation->hasParam('Grants')) { $command->overwriteWith($acp->toArray()); } else { $acp->updateCommand($command); } } // Remove the ACP parameter $command->remove('ACP'); } } } array('onCommandAfterPrepare', -255)); } /** * Changes how buckets are referenced in the HTTP request * * @param Event $event Event emitted */ public function onCommandAfterPrepare(Event $event) { $command = $event['command']; $bucket = $command['Bucket']; $request = $command->getRequest(); $pathStyle = false; if ($key = $command['Key']) { // Modify the command Key to account for the {/Key*} explosion into an array if (is_array($key)) { $command['Key'] = $key = implode('/', $key); } } // Set the key and bucket on the request $request->getParams()->set('bucket', $bucket)->set('key', $key); // Switch to virtual if PathStyle is disabled, or not a DNS compatible bucket name, or the scheme is // http, or the scheme is https and there are no dots in the host header (avoids SSL issues) if (!$command['PathStyle'] && $command->getClient()->isValidBucketName($bucket) && !($command->getRequest()->getScheme() == 'https' && strpos($bucket, '.')) ) { // Switch to virtual hosted bucket $request->setHost($bucket . '.' . $request->getHost()); $request->setPath(preg_replace("#^/{$bucket}#", '', $request->getPath())); } else { $pathStyle = true; } if (!$bucket) { $request->getParams()->set('s3.resource', '/'); } elseif ($pathStyle) { // Path style does not need a trailing slash $request->getParams()->set( 's3.resource', '/' . rawurlencode($bucket) . ($key ? ('/' . S3Client::encodeKey($key)) : '') ); } else { // Bucket style needs a trailing slash $request->getParams()->set( 's3.resource', '/' . rawurlencode($bucket) . ($key ? ('/' . S3Client::encodeKey($key)) : '/') ); } } } client->createPresignedUrl($this->prepare(), $expires); } /** * {@inheritdoc} */ protected function process() { $request = $this->getRequest(); $response = $this->getResponse(); // Dispatch an error if a 301 redirect occurred if ($response->getStatusCode() == 301) { $this->getClient()->getEventDispatcher()->dispatch('request.error', new Event(array( 'request' => $this->getRequest(), 'response' => $response ))); } parent::process(); // Set the GetObject URL if using the PutObject operation if ($this->result instanceof Model && $this->getName() == 'PutObject') { $this->result->set('ObjectURL', $request->getUrl()); } } } errors = $errors; } /** * Get the errored objects * * @return array Returns an array of associative arrays, each containing * a 'Code', 'Message', and 'Key' key. */ public function getErrors() { return $this->errors; } } getStatusCode() === 301) { $data['type'] = 'client'; if (isset($data['message'], $data['parsed'])) { $data['message'] = rtrim($data['message'], '.') . ': "' . $data['parsed']->Endpoint . '".'; } } return $data; } /** * {@inheritdoc} */ protected function parseHeaders(RequestInterface $request, Response $response, array &$data) { parent::parseHeaders($request, $response, $data); // Get the request $status = $response->getStatusCode(); $method = $request->getMethod(); // Attempt to determine code for 403s and 404s if ($status === 403) { $data['code'] = 'AccessDenied'; } elseif ($method === 'HEAD' && $status === 404) { $path = explode('/', trim($request->getPath(), '/')); $host = explode('.', $request->getHost()); $bucket = (count($host) === 4) ? $host[0] : array_shift($path); $object = array_shift($path); if ($bucket && $object) { $data['code'] = 'NoSuchKey'; } elseif ($bucket) { $data['code'] = 'NoSuchBucket'; } } } } get('Buckets') ?: array(); // If only the names_only set, change arrays to a string if ($this->get('names_only')) { foreach ($buckets as &$bucket) { $bucket = $bucket['Name']; } } return $buckets; } } get('Uploads') ?: array(); // If there are prefixes and we want them, merge them in if ($this->get('return_prefixes') && $result->hasKey('CommonPrefixes')) { $uploads = array_merge($uploads, $result->get('CommonPrefixes')); } return $uploads; } } get('Contents') ?: array(); $numObjects = count($objects); $lastKey = $numObjects ? $objects[$numObjects - 1]['Key'] : false; if ($lastKey && !$result->hasKey($this->get('token_key'))) { $result->set($this->get('token_key'), $lastKey); } // Closure for getting the name of an object or prefix $getName = function ($object) { return isset($object['Key']) ? $object['Key'] : $object['Prefix']; }; // If common prefixes returned (i.e. a delimiter was set) and they need to be returned, there is more to do if ($this->get('return_prefixes') && $result->hasKey('CommonPrefixes')) { // Collect and format the prefixes to include with the objects $objects = array_merge($objects, $result->get('CommonPrefixes')); // Sort the objects and prefixes to maintain alphabetical order, but only if some of each were returned if ($this->get('sort_results') && $lastKey && $objects) { usort($objects, function ($object1, $object2) use ($getName) { return strcmp($getName($object1), $getName($object2)); }); } } // If only the names are desired, iterate through the results and convert the arrays to the object/prefix names if ($this->get('names_only')) { $objects = array_map($getName, $objects); } return $objects; } } get('Versions') ?: array(); $deleteMarkers = $result->get('DeleteMarkers') ?: array(); $versions = array_merge($versions, $deleteMarkers); // If there are prefixes and we want them, merge them in if ($this->get('return_prefixes') && $result->hasKey('CommonPrefixes')) { $versions = array_merge($versions, $result->get('CommonPrefixes')); } return $versions; } } filePrefix = $filePrefix; $this->dirHandle = $dirHandle; $this->next(); } public function __destruct() { if ($this->dirHandle) { closedir($this->dirHandle); } } public function rewind() { $this->key = 0; rewinddir($this->dirHandle); } public function current() { return $this->currentFile; } public function next() { if ($file = readdir($this->dirHandle)) { $this->currentFile = new \SplFileInfo($this->filePrefix . $file); } else { $this->currentFile = false; } $this->key++; } public function key() { return $this->key; } public function valid() { return $this->currentFile !== false; } } setOwner($owner); $this->setGrants($grants); } /** * Create an Acp object from an array. This can be used to create an ACP from a response to a GetObject/Bucket ACL * operation. * * @param array $data Array of ACP data * * @return self */ public static function fromArray(array $data) { $builder = new AcpBuilder(); $builder->setOwner((string) $data['Owner']['ID'], $data['Owner']['DisplayName']); // Add each Grantee to the ACP foreach ($data['Grants'] as $grant) { $permission = $grant['Permission']; // Determine the type for response bodies that are missing the Type parameter if (!isset($grant['Grantee']['Type'])) { if (isset($grant['Grantee']['ID'])) { $grant['Grantee']['Type'] = 'CanonicalUser'; } elseif (isset($grant['Grantee']['URI'])) { $grant['Grantee']['Type'] = 'Group'; } else { $grant['Grantee']['Type'] = 'AmazonCustomerByEmail'; } } switch ($grant['Grantee']['Type']) { case 'Group': $builder->addGrantForGroup($permission, $grant['Grantee']['URI']); break; case 'AmazonCustomerByEmail': $builder->addGrantForEmail($permission, $grant['Grantee']['EmailAddress']); break; case 'CanonicalUser': $builder->addGrantForUser( $permission, $grant['Grantee']['ID'], $grant['Grantee']['DisplayName'] ); } } return $builder->build(); } /** * Set the owner of the ACP policy * * @param Grantee $owner ACP policy owner * * @return self * * @throws InvalidArgumentException if the grantee does not have an ID set */ public function setOwner(Grantee $owner) { if (!$owner->isCanonicalUser()) { throw new InvalidArgumentException('The owner must have an ID set.'); } $this->owner = $owner; return $this; } /** * Get the owner of the ACP policy * * @return Grantee */ public function getOwner() { return $this->owner; } /** * Set the grants for the ACP * * @param array|\Traversable $grants List of grants for the ACP * * @return self * * @throws InvalidArgumentException */ public function setGrants($grants = array()) { $this->grants = new \SplObjectStorage(); if ($grants) { if (is_array($grants) || $grants instanceof \Traversable) { /** @var $grant Grant */ foreach ($grants as $grant) { $this->addGrant($grant); } } else { throw new InvalidArgumentException('Grants must be passed in as an array or Traversable object.'); } } return $this; } /** * Get all of the grants * * @return \SplObjectStorage */ public function getGrants() { return $this->grants; } /** * Add a Grant * * @param Grant $grant Grant to add * * @return self */ public function addGrant(Grant $grant) { if (count($this->grants) < 100) { $this->grants->attach($grant); } else { throw new OverflowException('An ACP may contain up to 100 grants.'); } return $this; } /** * Get the total number of attributes * * @return int */ public function count() { return count($this->grants); } /** * Returns the grants for iteration * * @return \SplObjectStorage */ public function getIterator() { return $this->grants; } /** * Applies grant headers to a command's parameters * * @param AbstractCommand $command Command to be updated * * @return self */ public function updateCommand(AbstractCommand $command) { $parameters = array(); foreach ($this->grants as $grant) { /** @var $grant Grant */ $parameters = array_merge_recursive($parameters, $grant->getParameterArray()); } foreach ($parameters as $name => $values) { $command->set($name, implode(', ', (array) $values)); } return $this; } /** * {@inheritdoc} */ public function toArray() { $grants = array(); foreach ($this->grants as $grant) { $grants[] = $grant->toArray(); } return array( 'Owner' => array( 'ID' => $this->owner->getId(), 'DisplayName' => $this->owner->getDisplayName() ), 'Grants' => $grants ); } } owner = new Grantee($id, $displayName ?: $id, GranteeType::USER); return $this; } /** * Create and store a Grant with a CanonicalUser Grantee for the ACL * * @param string $permission Permission for the Grant * @param string $id Grantee identifier * @param string $displayName Grantee display name * * @return self */ public function addGrantForUser($permission, $id, $displayName = null) { $grantee = new Grantee($id, $displayName ?: $id, GranteeType::USER); $this->addGrant($permission, $grantee); return $this; } /** * Create and store a Grant with a AmazonCustomerByEmail Grantee for the ACL * * @param string $permission Permission for the Grant * @param string $email Grantee email address * * @return self */ public function addGrantForEmail($permission, $email) { $grantee = new Grantee($email, null, GranteeType::EMAIL); $this->addGrant($permission, $grantee); return $this; } /** * Create and store a Grant with a Group Grantee for the ACL * * @param string $permission Permission for the Grant * @param string $group Grantee group * * @return self */ public function addGrantForGroup($permission, $group) { $grantee = new Grantee($group, null, GranteeType::GROUP); $this->addGrant($permission, $grantee); return $this; } /** * Create and store a Grant for the ACL * * @param string $permission Permission for the Grant * @param Grantee $grantee The Grantee for the Grant * * @return self */ public function addGrant($permission, Grantee $grantee) { $this->grants[] = new Grant($grantee, $permission); return $this; } /** * Builds the ACP and returns it * * @return Acp */ public function build() { return new Acp($this->owner, $this->grants); } } client = $client; $this->bucket = $bucket; } /** * {@inheritdoc} */ public static function getAllEvents() { return array(self::AFTER_DELETE, self::BEFORE_CLEAR, self::AFTER_CLEAR); } /** * Set the bucket that is to be cleared * * @param string $bucket Name of the bucket to clear * * @return self */ public function setBucket($bucket) { $this->bucket = $bucket; return $this; } /** * Get the iterator used to yield the keys to be deleted. A default iterator * will be created and returned if no iterator has been explicitly set. * * @return \Iterator */ public function getIterator() { if (!$this->iterator) { $this->iterator = $this->client->getIterator('ListObjectVersions', array( 'Bucket' => $this->bucket )); } return $this->iterator; } /** * Sets a different iterator to use than the default iterator. This can be helpful when you wish to delete * only specific keys from a bucket (e.g. keys that match a certain prefix or delimiter, or perhaps keys that * pass through a filtered, decorated iterator). * * @param \Iterator $iterator Iterator used to yield the keys to be deleted * * @return self */ public function setIterator(\Iterator $iterator) { $this->iterator = $iterator; return $this; } /** * Set the MFA token to send with each request * * @param string $mfa MFA token to send with each request. The value is the concatenation of the authentication * device's serial number, a space, and the value displayed on your authentication device. * * @return self */ public function setMfa($mfa) { $this->mfa = $mfa; return $this; } /** * Clear the bucket * * @return int Returns the number of deleted keys * @throws ExceptionCollection */ public function clear() { $that = $this; $batch = DeleteObjectsBatch::factory($this->client, $this->bucket, $this->mfa); $batch = new NotifyingBatch($batch, function ($items) use ($that) { $that->dispatch(ClearBucket::AFTER_DELETE, array('keys' => $items)); }); $batch = new FlushingBatch(new ExceptionBufferingBatch($batch), 1000); // Let any listeners know that the bucket is about to be cleared $this->dispatch(self::BEFORE_CLEAR, array( 'iterator' => $this->getIterator(), 'batch' => $batch, 'mfa' => $this->mfa )); $deleted = 0; foreach ($this->getIterator() as $object) { if (isset($object['VersionId'])) { $versionId = $object['VersionId'] == 'null' ? null : $object['VersionId']; } else { $versionId = null; } $batch->addKey($object['Key'], $versionId); $deleted++; } $batch->flush(); // If any errors were encountered, then throw an ExceptionCollection if (count($batch->getExceptions())) { $e = new ExceptionCollection(); foreach ($batch->getExceptions() as $exception) { $e->add($exception->getPrevious()); } throw $e; } // Let any listeners know that the bucket was cleared $this->dispatch(self::AFTER_CLEAR, array('deleted' => $deleted)); return $deleted; } } %s, VersionId => %s] and call flush when the objects * should be deleted. */ class DeleteObjectsBatch extends AbstractBatchDecorator { /** * Factory for creating a DeleteObjectsBatch * * @param AwsClientInterface $client Client used to transfer requests * @param string $bucket Bucket that contains the objects to delete * @param string $mfa MFA token to use with the request * * @return self */ public static function factory(AwsClientInterface $client, $bucket, $mfa = null) { $batch = BatchBuilder::factory() ->createBatchesWith(new BatchSizeDivisor(1000)) ->transferWith(new DeleteObjectsTransfer($client, $bucket, $mfa)) ->build(); return new self($batch); } /** * Add an object to be deleted * * @param string $key Key of the object * @param string $versionId VersionID of the object * * @return self */ public function addKey($key, $versionId = null) { return $this->add(array( 'Key' => $key, 'VersionId' => $versionId )); } /** * {@inheritdoc} */ public function add($item) { if ($item instanceof AbstractCommand && $item->getName() == 'DeleteObject') { $item = array( 'Key' => $item['Key'], 'VersionId' => $item['VersionId'] ); } if (!is_array($item) || (!isset($item['Key']))) { throw new InvalidArgumentException('Item must be a DeleteObject command or array containing a Key and VersionId key.'); } return $this->decoratedBatch->add($item); } } client = $client; $this->bucket = $bucket; $this->mfa = $mfa; } /** * Set a new MFA token value * * @param string $token MFA token * * @return self */ public function setMfa($token) { $this->mfa = $token; return $this; } /** * {@inheritdoc} * @throws OverflowException if a batch has more than 1000 items * @throws InvalidArgumentException when an invalid batch item is encountered */ public function transfer(array $batch) { if (empty($batch)) { return; } if (count($batch) > 1000) { throw new OverflowException('Batches should be divided into chunks of no larger than 1000 keys'); } $del = array(); $command = $this->client->getCommand('DeleteObjects', array( 'Bucket' => $this->bucket, Ua::OPTION => Ua::BATCH )); if ($this->mfa) { $command->getRequestHeaders()->set('x-amz-mfa', $this->mfa); } foreach ($batch as $object) { // Ensure that the batch item is valid if (!is_array($object) || !isset($object['Key'])) { throw new InvalidArgumentException('Invalid batch item encountered: ' . var_export($batch, true)); } $del[] = array( 'Key' => $object['Key'], 'VersionId' => isset($object['VersionId']) ? $object['VersionId'] : null ); } $command['Objects'] = $del; $command->execute(); $this->processResponse($command); } /** * Process the response of the DeleteMultipleObjects request * * @paramCommandInterface $command Command executed */ protected function processResponse(CommandInterface $command) { $result = $command->getResult(); // Ensure that the objects were deleted successfully if (!empty($result['Errors'])) { $errors = $result['Errors']; throw new DeleteMultipleObjectsException($errors); } } } 'GrantRead', Permission::WRITE => 'GrantWrite', Permission::READ_ACP => 'GrantReadACP', Permission::WRITE_ACP => 'GrantWriteACP', Permission::FULL_CONTROL => 'GrantFullControl' ); /** * @var Grantee The grantee affected by the grant */ protected $grantee; /** * @var string The permission set by the grant */ protected $permission; /** * Constructs an ACL * * @param Grantee $grantee Affected grantee * @param string $permission Permission applied */ public function __construct(Grantee $grantee, $permission) { $this->setGrantee($grantee); $this->setPermission($permission); } /** * Set the grantee affected by the grant * * @param Grantee $grantee Affected grantee * * @return self */ public function setGrantee(Grantee $grantee) { $this->grantee = $grantee; return $this; } /** * Get the grantee affected by the grant * * @return Grantee */ public function getGrantee() { return $this->grantee; } /** * Set the permission set by the grant * * @param string $permission Permission applied * * @return self * * @throws InvalidArgumentException */ public function setPermission($permission) { $valid = Permission::values(); if (!in_array($permission, $valid)) { throw new InvalidArgumentException('The permission must be one of ' . 'the following: ' . implode(', ', $valid) . '.'); } $this->permission = $permission; return $this; } /** * Get the permission set by the grant * * @return string */ public function getPermission() { return $this->permission; } /** * Returns an array of the operation parameter and value to set on the operation * * @return array */ public function getParameterArray() { return array( self::$parameterMap[$this->permission] => $this->grantee->getHeaderValue() ); } /** * {@inheritdoc} */ public function toArray() { return array( 'Grantee' => $this->grantee->toArray(), 'Permission' => $this->permission ); } } 'id', GranteeType::EMAIL => 'emailAddress', GranteeType::GROUP => 'uri' ); /** * @var string The account ID, email, or URL identifying the grantee */ protected $id; /** * @var string The display name of the grantee */ protected $displayName; /** * @var string The type of the grantee (CanonicalUser or Group) */ protected $type; /** * Constructs a Grantee * * @param string $id Grantee identifier * @param string $displayName Grantee display name * @param string $expectedType The expected type of the grantee */ public function __construct($id, $displayName = null, $expectedType = null) { $this->type = GranteeType::USER; $this->setId($id, $expectedType); $this->setDisplayName($displayName); } /** * Sets the account ID, email, or URL identifying the grantee * * @param string $id Grantee identifier * @param string $expectedType The expected type of the grantee * * @return Grantee * * @throws UnexpectedValueException if $expectedType is set and the grantee * is not of that type after instantiation * @throws InvalidArgumentException when the ID provided is not a string */ public function setId($id, $expectedType = null) { if (in_array($id, Group::values())) { $this->type = GranteeType::GROUP; } elseif (!is_string($id)) { throw new InvalidArgumentException('The grantee ID must be provided as a string value.'); } if (strpos($id, '@') !== false) { $this->type = GranteeType::EMAIL; } if ($expectedType && $expectedType !== $this->type) { throw new UnexpectedValueException('The type of the grantee after ' . 'setting the ID did not match the specified, expected type "' . $expectedType . '" but received "' . $this->type . '".'); } $this->id = $id; return $this; } /** * Gets the grantee identifier * * @return string */ public function getId() { return $this->id; } /** * Gets the grantee email address (if it is set) * * @return null|string */ public function getEmailAddress() { return $this->isAmazonCustomerByEmail() ? $this->id : null; } /** * Gets the grantee URI (if it is set) * * @return null|string */ public function getGroupUri() { return $this->isGroup() ? $this->id : null; } /** * Sets the display name of the grantee * * @param string $displayName Grantee name * * @return Grantee * * @throws LogicException when the grantee type not CanonicalUser */ public function setDisplayName($displayName) { if ($this->type === GranteeType::USER) { if (empty($displayName) || !is_string($displayName)) { $displayName = $this->id; } $this->displayName = $displayName; } else { if ($displayName) { throw new LogicException('The display name can only be set ' . 'for grantees specified by ID.'); } } return $this; } /** * Gets the grantee display name * * @return string */ public function getDisplayName() { return $this->displayName; } /** * Gets the grantee type (determined by ID) * * @return string */ public function getType() { return $this->type; } /** * Returns true if this grantee object represents a canonical user by ID * * @return bool */ public function isCanonicalUser() { return ($this->type === GranteeType::USER); } /** * Returns true if this grantee object represents a customer by email * * @return bool */ public function isAmazonCustomerByEmail() { return ($this->type === GranteeType::EMAIL); } /** * Returns true if this grantee object represents a group by URL * * @return bool */ public function isGroup() { return ($this->type === GranteeType::GROUP); } /** * Returns the value used in headers to specify this grantee * * @return string */ public function getHeaderValue() { $key = self::$headerMap[$this->type]; return "{$key}=\"{$this->id}\""; } /** * {@inheritdoc} */ public function toArray() { $result = array( 'Type' => $this->type ); switch ($this->type) { case GranteeType::USER: $result['ID'] = $this->id; $result['DisplayName'] = $this->displayName; break; case GranteeType::EMAIL: $result['EmailAddress'] = $this->id; break; case GranteeType::GROUP: $result['URI'] = $this->id; } return $result; } } options = array_replace(array( 'min_part_size' => self::MIN_PART_SIZE, 'part_md5' => true ), $this->options); // Make sure the part size can be calculated somehow if (!$this->options['min_part_size'] && !$this->source->getContentLength()) { throw new RuntimeException('The ContentLength of the data source could not be determined, and no ' . 'min_part_size option was provided'); } } /** * {@inheritdoc} */ protected function calculatePartSize() { $partSize = $this->source->getContentLength() ? (int) ceil(($this->source->getContentLength() / self::MAX_PARTS)) : self::MIN_PART_SIZE; $partSize = max($this->options['min_part_size'], $partSize); $partSize = min($partSize, self::MAX_PART_SIZE); $partSize = max($partSize, self::MIN_PART_SIZE); return $partSize; } /** * {@inheritdoc} */ protected function complete() { /** @var $part UploadPart */ $parts = array(); foreach ($this->state as $part) { $parts[] = array( 'PartNumber' => $part->getPartNumber(), 'ETag' => $part->getETag(), ); } $params = $this->state->getUploadId()->toParams(); $params[Ua::OPTION] = Ua::MULTIPART_UPLOAD; $params['Parts'] = $parts; $command = $this->client->getCommand('CompleteMultipartUpload', $params); return $command->getResult(); } /** * {@inheritdoc} */ protected function getAbortCommand() { $params = $this->state->getUploadId()->toParams(); $params[Ua::OPTION] = Ua::MULTIPART_UPLOAD; /** @var $command OperationCommand */ $command = $this->client->getCommand('AbortMultipartUpload', $params); return $command; } } source->isLocal() || $this->source->getWrapper() != 'plainfile') { throw new RuntimeException('The source data must be a local file stream when uploading in parallel.'); } if (empty($this->options['concurrency'])) { throw new RuntimeException('The `concurrency` option must be specified when instantiating.'); } } /** * {@inheritdoc} */ protected function transfer() { $totalParts = (int) ceil($this->source->getContentLength() / $this->partSize); $concurrency = min($totalParts, $this->options['concurrency']); $partsToSend = $this->prepareParts($concurrency); $eventData = $this->getEventData(); while (!$this->stopped && count($this->state) < $totalParts) { $currentTotal = count($this->state); $commands = array(); for ($i = 0; $i < $concurrency && $i + $currentTotal < $totalParts; $i++) { // Move the offset to the correct position $partsToSend[$i]->setOffset(($currentTotal + $i) * $this->partSize); // @codeCoverageIgnoreStart if ($partsToSend[$i]->getContentLength() == 0) { break; } // @codeCoverageIgnoreEnd $params = $this->state->getUploadId()->toParams(); $eventData['command'] = $this->client->getCommand('UploadPart', array_replace($params, array( 'PartNumber' => count($this->state) + 1 + $i, 'Body' => $partsToSend[$i], 'ContentMD5' => (bool) $this->options['part_md5'], Ua::OPTION => Ua::MULTIPART_UPLOAD ))); $commands[] = $eventData['command']; // Notify any listeners of the part upload $this->dispatch(self::BEFORE_PART_UPLOAD, $eventData); } // Allow listeners to stop the transfer if needed if ($this->stopped) { break; } // Execute each command, iterate over the results, and add to the transfer state /** @var $command \Guzzle\Service\Command\OperationCommand */ foreach ($this->client->execute($commands) as $command) { $this->state->addPart(UploadPart::fromArray(array( 'PartNumber' => count($this->state) + 1, 'ETag' => $command->getResponse()->getEtag(), 'Size' => (int) $command->getResponse()->getContentLength(), 'LastModified' => gmdate(DateFormat::RFC2822) ))); $eventData['command'] = $command; // Notify any listeners the the part was uploaded $this->dispatch(self::AFTER_PART_UPLOAD, $eventData); } } } /** * Prepare the entity body handles to use while transferring * * @param int $concurrency Number of parts to prepare * * @return array Parts to send */ protected function prepareParts($concurrency) { $url = $this->source->getUri(); // Use the source EntityBody as the first part $parts = array(new ReadLimitEntityBody($this->source, $this->partSize)); // Open EntityBody handles for each part to upload in parallel for ($i = 1; $i < $concurrency; $i++) { $parts[] = new ReadLimitEntityBody(new EntityBody(fopen($url, 'r')), $this->partSize); } return $parts; } } stopped && !$this->source->isConsumed()) { if ($this->source->getContentLength() && $this->source->isSeekable()) { // If the stream is seekable and the Content-Length known, then stream from the data source $body = new ReadLimitEntityBody($this->source, $this->partSize, $this->source->ftell()); } else { // We need to read the data source into a temporary buffer before streaming $body = EntityBody::factory(); while ($body->getContentLength() < $this->partSize && $body->write( $this->source->read(max(1, min(10 * Size::KB, $this->partSize - $body->getContentLength()))) )); } // @codeCoverageIgnoreStart if ($body->getContentLength() == 0) { break; } // @codeCoverageIgnoreEnd $params = $this->state->getUploadId()->toParams(); $command = $this->client->getCommand('UploadPart', array_replace($params, array( 'PartNumber' => count($this->state) + 1, 'Body' => $body, 'ContentMD5' => (bool) $this->options['part_md5'], Ua::OPTION => Ua::MULTIPART_UPLOAD ))); // Notify observers that the part is about to be uploaded $eventData = $this->getEventData(); $eventData['command'] = $command; $this->dispatch(self::BEFORE_PART_UPLOAD, $eventData); // Allow listeners to stop the transfer if needed if ($this->stopped) { break; } $response = $command->getResponse(); $this->state->addPart(UploadPart::fromArray(array( 'PartNumber' => count($this->state) + 1, 'ETag' => $response->getEtag(), 'Size' => $body->getContentLength(), 'LastModified' => gmdate(DateFormat::RFC2822) ))); // Notify observers that the part was uploaded $this->dispatch(self::AFTER_PART_UPLOAD, $eventData); } } } getIterator('ListParts', $uploadId->toParams()) as $part) { $transferState->addPart(UploadPart::fromArray($part)); } return $transferState; } } setOption('Bucket', $bucket); } /** * Set the key of the object * * @param string $key Key of the object to upload * * @return self */ public function setKey($key) { return $this->setOption('Key', $key); } /** * Set the minimum acceptable part size * * @param int $minSize Minimum acceptable part size in bytes * * @return self */ public function setMinPartSize($minSize) { $this->minPartSize = (int) max((int) $minSize, AbstractTransfer::MIN_PART_SIZE); return $this; } /** * Set the concurrency level to use when uploading parts. This affects how * many parts are uploaded in parallel. You must use a local file as your * data source when using a concurrency greater than 1 * * @param int $concurrency Concurrency level * * @return self */ public function setConcurrency($concurrency) { $this->concurrency = $concurrency; return $this; } /** * Explicitly set the MD5 hash of the entire body * * @param string $md5 MD5 hash of the entire body * * @return self */ public function setMd5($md5) { $this->md5 = $md5; return $this; } /** * Set to true to have the builder calculate the MD5 hash of the entire data * source before initiating a multipart upload (this could be an expensive * operation). This setting can ony be used with seekable data sources. * * @param bool $calculateMd5 Set to true to calculate the MD5 hash of the body * * @return self */ public function calculateMd5($calculateMd5) { $this->calculateEntireMd5 = (bool) $calculateMd5; return $this; } /** * Specify whether or not to calculate the MD5 hash of each uploaded part. * This setting defaults to true. * * @param bool $usePartMd5 Set to true to calculate the MD5 has of each part * * @return self */ public function calculatePartMd5($usePartMd5) { $this->calculatePartMd5 = (bool) $usePartMd5; return $this; } /** * Set the ACP to use on the object * * @param Acp $acp ACP to set on the object * * @return self */ public function setAcp(Acp $acp) { return $this->setOption('ACP', $acp); } /** * Set an option to pass to the initial CreateMultipartUpload operation * * @param string $name Option name * @param string $value Option value * * @return self */ public function setOption($name, $value) { $this->commandOptions[$name] = $value; return $this; } /** * Add an array of options to pass to the initial CreateMultipartUpload operation * * @param array $options Array of CreateMultipartUpload operation parameters * * @return self */ public function addOptions(array $options) { $this->commandOptions = array_replace($this->commandOptions, $options); return $this; } /** * Set an array of transfer options to apply to the upload transfer object * * @param array $options Transfer options * * @return self */ public function setTransferOptions(array $options) { $this->transferOptions = $options; return $this; } /** * {@inheritdoc} * @throws InvalidArgumentException when attempting to resume a transfer using a non-seekable stream * @throws InvalidArgumentException when missing required properties (bucket, key, client, source) */ public function build() { if ($this->state instanceof TransferState) { $this->commandOptions = array_replace($this->commandOptions, $this->state->getUploadId()->toParams()); } if (!isset($this->commandOptions['Bucket']) || !isset($this->commandOptions['Key']) || !$this->client || !$this->source ) { throw new InvalidArgumentException('You must specify a Bucket, Key, client, and source.'); } if ($this->state && !$this->source->isSeekable()) { throw new InvalidArgumentException('You cannot resume a transfer using a non-seekable source.'); } // If no state was set, then create one by initiating or loading a multipart upload if (is_string($this->state)) { $this->state = TransferState::fromUploadId($this->client, UploadId::fromParams(array( 'Bucket' => $this->commandOptions['Bucket'], 'Key' => $this->commandOptions['Key'], 'UploadId' => $this->state ))); } elseif (!$this->state) { $this->state = $this->initiateMultipartUpload(); } $options = array_replace(array( 'min_part_size' => $this->minPartSize, 'part_md5' => (bool) $this->calculatePartMd5, 'concurrency' => $this->concurrency ), $this->transferOptions); return $this->concurrency > 1 ? new ParallelTransfer($this->client, $this->state, $this->source, $options) : new SerialTransfer($this->client, $this->state, $this->source, $options); } /** * {@inheritdoc} */ protected function initiateMultipartUpload() { // Determine Content-Type if ($mimeType = $this->source->getContentType()) { $this->commandOptions['ContentType'] = $mimeType; } $params = array_replace(array( Ua::OPTION => Ua::MULTIPART_UPLOAD, 'command.headers' => $this->headers, 'Metadata' => array() ), $this->commandOptions); // Calculate the MD5 hash if none was set and it is asked of the builder if ($this->calculateEntireMd5) { $this->md5 = $this->source->getContentMd5(); } // If an MD5 is specified, then add it to the custom headers of the request // so that it will be returned when downloading the object from Amazon S3 if ($this->md5) { $params['Metadata']['x-amz-Content-MD5'] = $this->md5; } $result = $this->client->getCommand('CreateMultipartUpload', $params)->execute(); // Create a new state based on the initiated upload $params['UploadId'] = $result['UploadId']; return new TransferState(UploadId::fromParams($params)); } } false, 'Key' => false, 'UploadId' => false ); } 'partNumber', 'ETag' => 'eTag', 'LastModified' => 'lastModified', 'Size' => 'size' ); /** * @var string The ETag for this part */ protected $eTag; /** * @var string The last modified date */ protected $lastModified; /** * @var int The size (or content-length) in bytes of the upload body */ protected $size; /** * @return string */ public function getETag() { return $this->eTag; } /** * @return string */ public function getLastModified() { return $this->lastModified; } /** * @return int */ public function getSize() { return $this->size; } } tag attributes as an array */ protected $formAttributes; /** * @var array The form's elements as an array */ protected $formInputs; /** * @var string The raw json policy */ protected $jsonPolicy; /** * Constructs the PostObject * * The options array accepts the following keys: * * - acl: The access control setting to apply to the uploaded file. Accepts any of the * CannedAcl constants * - Cache-Control: The Cache-Control HTTP header value to apply to the uploaded file * - Content-Disposition: The Content-Disposition HTTP header value to apply to the uploaded file * - Content-Encoding: The Content-Encoding HTTP header value to apply to the uploaded file * - Content-Type: The Content-Type HTTP header value to apply to the uploaded file. The default * value is `application/octet-stream` * - Expires: The Expires HTTP header value to apply to the uploaded file * - key: The location where the file should be uploaded to. The default value is * `^${filename}` which will use the name of the uploaded file * - policy: A raw policy in JSON format. By default, the PostObject creates one for you * - success_action_redirect: The URI for Amazon S3 to redirect to upon successful upload * - success_action_status: The status code for Amazon S3 to return upon successful upload * - ttd: The expiration time for the generated upload form data * - x-amz-server-side-encryption: The server-side encryption mechanism to use * - x-amz-storage-class: The storage setting to apply to the object * - x-amz-meta-*: Any custom meta tag that should be set to the object * * For the Cache-Control, Content-Disposition, Content-Encoding, * Content-Type, Expires, and key options, to use a "starts-with" comparison * instead of an equals comparison, prefix the value with a ^ (carat) * character * * @param S3Client $client * @param $bucket * @param array $options */ public function __construct(S3Client $client, $bucket, array $options = array()) { $this->setClient($client); $this->setBucket($bucket); parent::__construct($options); } /** * Analyzes the provided data and turns it into useful data that can be * consumed and used to build an upload form * * @return PostObject */ public function prepareData() { // Validate required options $options = Collection::fromConfig($this->data, array( 'ttd' => '+1 hour', 'key' => '^${filename}', )); // Format ttd option $ttd = $options['ttd']; $ttd = is_numeric($ttd) ? (int) $ttd : strtotime($ttd); unset($options['ttd']); // Save policy if passed in $rawPolicy = $options['policy']; unset($options['policy']); // Setup policy document $policy = array( 'expiration' => gmdate(DateFormat::ISO8601_S3, $ttd), 'conditions' => array(array('bucket' => $this->bucket)) ); // Configure the endpoint/action $url = Url::factory($this->client->getBaseUrl()); $url->setHost($this->bucket . '.' . $url->getHost()); // Setup basic form $this->formAttributes = array( 'action' => (string) $url, 'method' => 'POST', 'enctype' => 'multipart/form-data' ); $this->formInputs = array( 'AWSAccessKeyId' => $this->client->getCredentials()->getAccessKeyId() ); // Add success action status $status = (int) $options->get('success_action_status'); if ($status && in_array($status, array(200, 201, 204))) { $this->formInputs['success_action_status'] = (string) $status; $policy['conditions'][] = array( 'success_action_status' => (string) $status ); $options->remove('success_action_status'); } // Add other options foreach ($options as $key => $value) { $value = (string) $value; if ($value[0] === '^') { $value = substr($value, 1); $this->formInputs[$key] = $value; $value = preg_replace('/\$\{(\w*)\}/', '', $value); $policy['conditions'][] = array('starts-with', '$' . $key, $value); } else { $this->formInputs[$key] = $value; $policy['conditions'][] = array($key => $value); } } // Add policy $this->jsonPolicy = $rawPolicy ?: json_encode($policy); $jsonPolicy64 = base64_encode($this->jsonPolicy); $this->formInputs['policy'] = $jsonPolicy64; // Add signature $this->formInputs['signature'] = base64_encode(hash_hmac( 'sha1', $jsonPolicy64, $this->client->getCredentials()->getSecretKey(), true )); return $this; } /** * Sets the S3 client * * @param S3Client $client * * @return PostObject */ public function setClient(S3Client $client) { $this->client = $client; return $this; } /** * Gets the S3 client * * @return S3Client */ public function getClient() { return $this->client; } /** * Sets the bucket and makes sure it is a valid bucket name * * @param string $bucket * * @return PostObject */ public function setBucket($bucket) { $this->bucket = $bucket; return $this; } /** * Gets the bucket name * * @return string */ public function getBucket() { return $this->bucket; } /** * Gets the form attributes as an array * * @return array */ public function getFormAttributes() { return $this->formAttributes; } /** * Gets the form inputs as an array * * @return array */ public function getFormInputs() { return $this->formInputs; } /** * Gets the raw JSON policy * * @return string */ public function getJsonPolicy() { return $this->jsonPolicy; } } '2006-03-01', 'endpointPrefix' => 's3', 'serviceFullName' => 'Amazon Simple Storage Service', 'serviceAbbreviation' => 'Amazon S3', 'serviceType' => 'rest-xml', 'timestampFormat' => 'rfc822', 'globalEndpoint' => 's3.amazonaws.com', 'signatureVersion' => 's3', 'namespace' => 'S3', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 's3-us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 's3-ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 's3-us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AbortMultipartUpload' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'AbortMultipartUploadOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadAbort.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), ), 'errorResponses' => array( array( 'reason' => 'The specified multipart upload does not exist.', 'class' => 'NoSuchUploadException', ), ), ), 'CompleteMultipartUpload' => array( 'httpMethod' => 'POST', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'CompleteMultipartUploadOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadComplete.html', 'data' => array( 'xmlRoot' => array( 'name' => 'CompleteMultipartUpload', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Parts' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Part', 'properties' => array( 'ETag' => array( 'type' => 'string', ), 'PartNumber' => array( 'type' => 'numeric', ), ), ), ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'CopyObject' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'CopyObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectCOPY.html', 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'CopySource' => array( 'required' => true, 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source', ), 'CopySourceIfMatch' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-match', ), 'CopySourceIfModifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-modified-since', ), 'CopySourceIfNoneMatch' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-none-match', ), 'CopySourceIfUnmodifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-unmodified-since', ), 'Expires' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'MetadataDirective' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-metadata-directive', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'StorageClass' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-storage-class', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The source object of the COPY operation is not in the active tier and is only stored in Amazon Glacier.', 'class' => 'ObjectNotInActiveTierErrorException', ), ), ), 'CreateBucket' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'CreateBucketOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUT.html', 'data' => array( 'xmlRoot' => array( 'name' => 'CreateBucketConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'LocationConstraint' => array( 'type' => 'string', 'location' => 'xml', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWrite' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), ), 'errorResponses' => array( array( 'reason' => 'The requested bucket name is not available. The bucket namespace is shared by all users of the system. Please select a different name and try again.', 'class' => 'BucketAlreadyExistsException', ), ), ), 'CreateMultipartUpload' => array( 'httpMethod' => 'POST', 'uri' => '/{Bucket}{/Key*}?uploads', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'CreateMultipartUploadOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadInitiate.html', 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'Expires' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'StorageClass' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-storage-class', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'DeleteBucket' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETE.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketCors' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?cors', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketCorsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEcors.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketLifecycle' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?lifecycle', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketLifecycleOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETElifecycle.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketPolicy' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?policy', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketPolicyOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEpolicy.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketTagging' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?tagging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketTaggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEtagging.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteBucketWebsite' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}?website', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteBucketWebsiteOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEwebsite.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'DeleteObject' => array( 'httpMethod' => 'DELETE', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectDELETE.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'MFA' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-mfa', ), 'VersionId' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'versionId', ), ), ), 'DeleteObjects' => array( 'httpMethod' => 'POST', 'uri' => '/{Bucket}?delete', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'DeleteObjectsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/multiobjectdeleteapi.html', 'data' => array( 'xmlRoot' => array( 'name' => 'Delete', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'contentMd5' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Objects' => array( 'required' => true, 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Object', 'properties' => array( 'Key' => array( 'required' => true, 'type' => 'string', ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'Quiet' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'xml', ), 'MFA' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-mfa', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketAcl' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?acl', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketAclOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETacl.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketCors' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?cors', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketCorsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETcors.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketLifecycle' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?lifecycle', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketLifecycleOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETlifecycle.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketLocation' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?location', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketLocationOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETlocation.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'GetBucketLogging' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?logging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketLoggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETlogging.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketNotification' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?notification', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketNotificationOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETnotification.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketPolicy' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?policy', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketPolicyOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETpolicy.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), ), 'GetBucketRequestPayment' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?requestPayment', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketRequestPaymentOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTrequestPaymentGET.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketTagging' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?tagging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketTaggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETtagging.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketVersioning' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?versioning', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketVersioningOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETversioningStatus.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetBucketWebsite' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?website', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetBucketWebsiteOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETwebsite.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'GetObject' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectGET.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'IfModifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'If-Modified-Since', ), 'IfNoneMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-None-Match', ), 'IfUnmodifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'If-Unmodified-Since', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Range' => array( 'type' => 'string', 'location' => 'header', ), 'ResponseCacheControl' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-cache-control', ), 'ResponseContentDisposition' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-content-disposition', ), 'ResponseContentEncoding' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-content-encoding', ), 'ResponseContentLanguage' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-content-language', ), 'ResponseContentType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'response-content-type', ), 'ResponseExpires' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'query', 'sentAs' => 'response-expires', ), 'VersionId' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'versionId', ), 'SaveAs' => array( 'location' => 'response_body', ), ), 'errorResponses' => array( array( 'reason' => 'The specified key does not exist.', 'class' => 'NoSuchKeyException', ), ), ), 'GetObjectAcl' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}{/Key*}?acl', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetObjectAclOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectGETacl.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'VersionId' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'versionId', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified key does not exist.', 'class' => 'NoSuchKeyException', ), ), ), 'GetObjectTorrent' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}{/Key*}?torrent', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'GetObjectTorrentOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectGETtorrent.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), ), ), 'HeadBucket' => array( 'httpMethod' => 'HEAD', 'uri' => '/{Bucket}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'HeadBucketOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketHEAD.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), ), 'errorResponses' => array( array( 'reason' => 'The specified bucket does not exist.', 'class' => 'NoSuchBucketException', ), ), ), 'HeadObject' => array( 'httpMethod' => 'HEAD', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'HeadObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectHEAD.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'IfMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-Match', ), 'IfModifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'If-Modified-Since', ), 'IfNoneMatch' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'If-None-Match', ), 'IfUnmodifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'If-Unmodified-Since', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Range' => array( 'type' => 'string', 'location' => 'header', ), 'VersionId' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'versionId', ), ), 'errorResponses' => array( array( 'reason' => 'The specified key does not exist.', 'class' => 'NoSuchKeyException', ), ), ), 'ListBuckets' => array( 'httpMethod' => 'GET', 'uri' => '/', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListBucketsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTServiceGET.html', 'parameters' => array( 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'ListMultipartUploads' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?uploads', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListMultipartUploadsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadListMPUpload.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Delimiter' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'delimiter', ), 'EncodingType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'encoding-type', ), 'KeyMarker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'key-marker', ), 'MaxUploads' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'max-uploads', ), 'Prefix' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'prefix', ), 'UploadIdMarker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'upload-id-marker', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'ListObjectVersions' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}?versions', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListObjectVersionsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETVersion.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Delimiter' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'delimiter', ), 'EncodingType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'encoding-type', ), 'KeyMarker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'key-marker', ), 'MaxKeys' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'max-keys', ), 'Prefix' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'prefix', ), 'VersionIdMarker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'version-id-marker', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'ListObjects' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListObjectsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGET.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Delimiter' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'delimiter', ), 'EncodingType' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'encoding-type', ), 'Marker' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'marker', ), 'MaxKeys' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'max-keys', ), 'Prefix' => array( 'type' => 'string', 'location' => 'query', 'sentAs' => 'prefix', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), 'errorResponses' => array( array( 'reason' => 'The specified bucket does not exist.', 'class' => 'NoSuchBucketException', ), ), ), 'ListParts' => array( 'httpMethod' => 'GET', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'ListPartsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadListParts.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'MaxParts' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'max-parts', ), 'PartNumberMarker' => array( 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'part-number-marker', ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), 'PutBucketAcl' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?acl', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketAclOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTacl.html', 'data' => array( 'xmlRoot' => array( 'name' => 'AccessControlPolicy', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Grants' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'AccessControlList', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWrite' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), ), ), 'PutBucketCors' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?cors', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketCorsOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTcors.html', 'data' => array( 'xmlRoot' => array( 'name' => 'CORSConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'contentMd5' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CORSRules' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'CORSRule', 'properties' => array( 'AllowedHeaders' => array( 'type' => 'array', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedHeader', ), ), 'AllowedMethods' => array( 'type' => 'array', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedMethod', ), ), 'AllowedOrigins' => array( 'type' => 'array', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedOrigin', ), ), 'ExposeHeaders' => array( 'type' => 'array', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'ExposeHeader', ), ), 'MaxAgeSeconds' => array( 'type' => 'numeric', ), ), ), ), ), ), 'PutBucketLifecycle' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?lifecycle', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketLifecycleOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTlifecycle.html', 'data' => array( 'xmlRoot' => array( 'name' => 'LifecycleConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'contentMd5' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Rules' => array( 'required' => true, 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Rule', 'properties' => array( 'Expiration' => array( 'type' => 'object', 'properties' => array( 'Date' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', ), 'Days' => array( 'type' => 'numeric', ), ), ), 'ID' => array( 'type' => 'string', ), 'Prefix' => array( 'required' => true, 'type' => 'string', ), 'Status' => array( 'required' => true, 'type' => 'string', ), 'Transition' => array( 'type' => 'object', 'properties' => array( 'Date' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time', ), 'Days' => array( 'type' => 'numeric', ), 'StorageClass' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'PutBucketLogging' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?logging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketLoggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTlogging.html', 'data' => array( 'xmlRoot' => array( 'name' => 'BucketLoggingStatus', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'xmlAllowEmpty' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'LoggingEnabled' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetBucket' => array( 'type' => 'string', ), 'TargetGrants' => array( 'type' => 'array', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'TargetPrefix' => array( 'type' => 'string', ), ), ), ), ), 'PutBucketNotification' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?notification', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketNotificationOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTnotification.html', 'data' => array( 'xmlRoot' => array( 'name' => 'NotificationConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'TopicConfiguration' => array( 'required' => true, 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Event' => array( 'type' => 'string', ), 'Topic' => array( 'type' => 'string', ), ), ), ), ), 'PutBucketPolicy' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?policy', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketPolicyOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTpolicy.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Policy' => array( 'required' => true, 'type' => array( 'string', 'object', ), 'location' => 'body', ), ), ), 'PutBucketRequestPayment' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?requestPayment', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketRequestPaymentOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTrequestPaymentPUT.html', 'data' => array( 'xmlRoot' => array( 'name' => 'RequestPaymentConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Payer' => array( 'required' => true, 'type' => 'string', 'location' => 'xml', ), ), ), 'PutBucketTagging' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?tagging', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketTaggingOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTtagging.html', 'data' => array( 'xmlRoot' => array( 'name' => 'Tagging', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'contentMd5' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'TagSet' => array( 'required' => true, 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Tag', 'required' => true, 'type' => 'object', 'properties' => array( 'Key' => array( 'required' => true, 'type' => 'string', ), 'Value' => array( 'required' => true, 'type' => 'string', ), ), ), ), ), ), 'PutBucketVersioning' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?versioning', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketVersioningOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTVersioningStatus.html', 'data' => array( 'xmlRoot' => array( 'name' => 'VersioningConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'MFA' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-mfa', ), 'MFADelete' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'PutBucketWebsite' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}?website', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutBucketWebsiteOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTwebsite.html', 'data' => array( 'xmlRoot' => array( 'name' => 'WebsiteConfiguration', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), 'xmlAllowEmpty' => true, ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'ErrorDocument' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Key' => array( 'required' => true, 'type' => 'string', ), ), ), 'IndexDocument' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Suffix' => array( 'required' => true, 'type' => 'string', ), ), ), 'RedirectAllRequestsTo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'HostName' => array( 'required' => true, 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), ), ), 'RoutingRules' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'RoutingRule', 'type' => 'object', 'properties' => array( 'Condition' => array( 'type' => 'object', 'properties' => array( 'HttpErrorCodeReturnedEquals' => array( 'type' => 'string', ), 'KeyPrefixEquals' => array( 'type' => 'string', ), ), ), 'Redirect' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'HostName' => array( 'type' => 'string', ), 'HttpRedirectCode' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), 'ReplaceKeyPrefixWith' => array( 'type' => 'string', ), 'ReplaceKeyWith' => array( 'type' => 'string', ), ), ), ), ), ), ), ), 'PutObject' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectPUT.html', 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Body' => array( 'type' => array( 'string', 'object', ), 'location' => 'body', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentLength' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'Content-Length', ), 'ContentMD5' => array( 'type' => array( 'string', 'boolean', ), 'location' => 'header', 'sentAs' => 'Content-MD5', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'Expires' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'StorageClass' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-storage-class', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), ), ), 'PutObjectAcl' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}?acl', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'PutObjectAclOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectPUTacl.html', 'data' => array( 'xmlRoot' => array( 'name' => 'AccessControlPolicy', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'ACL' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-acl', ), 'Grants' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'AccessControlList', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'GrantFullControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-full-control', ), 'GrantRead' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read', ), 'GrantReadACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-read-acp', ), 'GrantWrite' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write', ), 'GrantWriteACP' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-grant-write-acp', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'ACP' => array( 'type' => 'object', 'additionalProperties' => true, ), ), 'errorResponses' => array( array( 'reason' => 'The specified key does not exist.', 'class' => 'NoSuchKeyException', ), ), ), 'RestoreObject' => array( 'httpMethod' => 'POST', 'uri' => '/{Bucket}{/Key*}?restore', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'RestoreObjectOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectRestore.html', 'data' => array( 'xmlRoot' => array( 'name' => 'RestoreRequest', 'namespaces' => array( 'http://s3.amazonaws.com/doc/2006-03-01/', ), ), ), 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'Days' => array( 'required' => true, 'type' => 'numeric', 'location' => 'xml', ), ), 'errorResponses' => array( array( 'reason' => 'This operation is not allowed against this storage tier', 'class' => 'ObjectAlreadyInActiveTierErrorException', ), ), ), 'UploadPart' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'UploadPartOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadUploadPart.html', 'parameters' => array( 'Body' => array( 'type' => array( 'string', 'object', ), 'location' => 'body', ), 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'ContentLength' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'Content-Length', ), 'ContentMD5' => array( 'type' => array( 'string', 'boolean', ), 'location' => 'header', 'sentAs' => 'Content-MD5', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'PartNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'partNumber', ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), ), ), 'UploadPartCopy' => array( 'httpMethod' => 'PUT', 'uri' => '/{Bucket}{/Key*}', 'class' => 'Aws\\S3\\Command\\S3Command', 'responseClass' => 'UploadPartCopyOutput', 'responseType' => 'model', 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadUploadPartCopy.html', 'parameters' => array( 'Bucket' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', ), 'CopySource' => array( 'required' => true, 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source', ), 'CopySourceIfMatch' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-match', ), 'CopySourceIfModifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-modified-since', ), 'CopySourceIfNoneMatch' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-none-match', ), 'CopySourceIfUnmodifiedSince' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'date-time-http', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-if-unmodified-since', ), 'CopySourceRange' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-range', ), 'Key' => array( 'required' => true, 'type' => 'string', 'location' => 'uri', 'filters' => array( 'Aws\\S3\\S3Client::explodeKey', ), ), 'PartNumber' => array( 'required' => true, 'type' => 'numeric', 'location' => 'query', 'sentAs' => 'partNumber', ), 'UploadId' => array( 'required' => true, 'type' => 'string', 'location' => 'query', 'sentAs' => 'uploadId', ), 'command.expects' => array( 'static' => true, 'default' => 'application/xml', ), ), ), ), 'models' => array( 'AbortMultipartUploadOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CompleteMultipartUploadOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Bucket' => array( 'type' => 'string', 'location' => 'xml', ), 'ETag' => array( 'type' => 'string', 'location' => 'xml', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'Key' => array( 'type' => 'string', 'location' => 'xml', ), 'Location' => array( 'type' => 'string', 'location' => 'xml', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CopyObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ETag' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModified' => array( 'type' => 'string', 'location' => 'xml', ), 'CopySourceVersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-version-id', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateBucketOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Location' => array( 'type' => 'string', 'location' => 'header', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'CreateMultipartUploadOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Bucket' => array( 'type' => 'string', 'location' => 'xml', 'sentAs' => 'Bucket', ), 'Key' => array( 'type' => 'string', 'location' => 'xml', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'UploadId' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketCorsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketLifecycleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketPolicyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketTaggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteBucketWebsiteOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DeleteMarker' => array( 'type' => 'boolean', 'location' => 'header', 'sentAs' => 'x-amz-delete-marker', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'DeleteObjectsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Deleted' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'DeleteMarker' => array( 'type' => 'boolean', ), 'DeleteMarkerVersionId' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'Errors' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Error', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Error', 'properties' => array( 'Code' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketAclOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Grants' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'AccessControlList', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'sentAs' => 'Grant', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketCorsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CORSRules' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'CORSRule', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'CORSRule', 'properties' => array( 'AllowedHeaders' => array( 'type' => 'array', 'sentAs' => 'AllowedHeader', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedHeader', ), ), 'AllowedMethods' => array( 'type' => 'array', 'sentAs' => 'AllowedMethod', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedMethod', ), ), 'AllowedOrigins' => array( 'type' => 'array', 'sentAs' => 'AllowedOrigin', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'AllowedOrigin', ), ), 'ExposeHeaders' => array( 'type' => 'array', 'sentAs' => 'ExposeHeader', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'string', 'sentAs' => 'ExposeHeader', ), ), 'MaxAgeSeconds' => array( 'type' => 'numeric', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketLifecycleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Rules' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Rule', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Rule', 'properties' => array( 'Expiration' => array( 'type' => 'object', 'properties' => array( 'Date' => array( 'type' => 'string', ), 'Days' => array( 'type' => 'numeric', ), ), ), 'ID' => array( 'type' => 'string', ), 'Prefix' => array( 'type' => 'string', ), 'Status' => array( 'type' => 'string', ), 'Transition' => array( 'type' => 'object', 'properties' => array( 'Date' => array( 'type' => 'string', ), 'Days' => array( 'type' => 'numeric', ), 'StorageClass' => array( 'type' => 'string', ), ), ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketLocationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Location' => array( 'type' => 'string', 'location' => 'body', 'filters' => array( 'strval', 'strip_tags', 'trim', ), ), ), ), 'GetBucketLoggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'LoggingEnabled' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'TargetBucket' => array( 'type' => 'string', ), 'TargetGrants' => array( 'type' => 'array', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'sentAs' => 'Grant', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'TargetPrefix' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketNotificationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TopicConfiguration' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Event' => array( 'type' => 'string', ), 'Topic' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketPolicyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Policy' => array( 'type' => 'string', 'instanceOf' => 'Guzzle\\Http\\EntityBody', 'location' => 'body', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketRequestPaymentOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Payer' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketTaggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TagSet' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Tag', 'type' => 'object', 'sentAs' => 'Tag', 'properties' => array( 'Key' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketVersioningOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MFADelete' => array( 'type' => 'string', 'location' => 'xml', ), 'Status' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetBucketWebsiteOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ErrorDocument' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Key' => array( 'type' => 'string', ), ), ), 'IndexDocument' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'Suffix' => array( 'type' => 'string', ), ), ), 'RedirectAllRequestsTo' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'HostName' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), ), ), 'RoutingRules' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'RoutingRule', 'type' => 'object', 'sentAs' => 'RoutingRule', 'properties' => array( 'Condition' => array( 'type' => 'object', 'properties' => array( 'HttpErrorCodeReturnedEquals' => array( 'type' => 'string', ), 'KeyPrefixEquals' => array( 'type' => 'string', ), ), ), 'Redirect' => array( 'type' => 'object', 'properties' => array( 'HostName' => array( 'type' => 'string', ), 'HttpRedirectCode' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), 'ReplaceKeyPrefixWith' => array( 'type' => 'string', ), 'ReplaceKeyWith' => array( 'type' => 'string', ), ), ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AcceptRanges' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'accept-ranges', ), 'Body' => array( 'type' => 'string', 'instanceOf' => 'Guzzle\\Http\\EntityBody', 'location' => 'body', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentLength' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'Content-Length', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'DeleteMarker' => array( 'type' => 'boolean', 'location' => 'header', 'sentAs' => 'x-amz-delete-marker', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'Expires' => array( 'type' => 'string', 'location' => 'header', ), 'LastModified' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Last-Modified', ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'MissingMeta' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'x-amz-missing-meta', ), 'Restore' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-restore', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetObjectAclOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Grants' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'AccessControlList', 'items' => array( 'name' => 'Grant', 'type' => 'object', 'sentAs' => 'Grant', 'properties' => array( 'Grantee' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'EmailAddress' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), 'Type' => array( 'type' => 'string', 'sentAs' => 'xsi:type', 'data' => array( 'xmlAttribute' => true, 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', ), ), 'URI' => array( 'type' => 'string', ), ), ), 'Permission' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'GetObjectTorrentOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Body' => array( 'type' => 'string', 'instanceOf' => 'Guzzle\\Http\\EntityBody', 'location' => 'body', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'HeadBucketOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'HeadObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'AcceptRanges' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'accept-ranges', ), 'CacheControl' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Cache-Control', ), 'ContentDisposition' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Disposition', ), 'ContentEncoding' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Encoding', ), 'ContentLanguage' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Language', ), 'ContentLength' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'Content-Length', ), 'ContentType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Content-Type', ), 'DeleteMarker' => array( 'type' => 'boolean', 'location' => 'header', 'sentAs' => 'x-amz-delete-marker', ), 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'Expires' => array( 'type' => 'string', 'location' => 'header', ), 'LastModified' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Last-Modified', ), 'Metadata' => array( 'type' => 'object', 'location' => 'header', 'sentAs' => 'x-amz-meta-', 'additionalProperties' => array( 'type' => 'string', ), ), 'MissingMeta' => array( 'type' => 'numeric', 'location' => 'header', 'sentAs' => 'x-amz-missing-meta', ), 'Restore' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-restore', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'WebsiteRedirectLocation' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-website-redirect-location', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListBucketsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Buckets' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Bucket', 'type' => 'object', 'sentAs' => 'Bucket', 'properties' => array( 'CreationDate' => array( 'type' => 'string', ), 'Name' => array( 'type' => 'string', ), ), ), ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListMultipartUploadsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Bucket' => array( 'type' => 'string', 'location' => 'xml', ), 'CommonPrefixes' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'Prefix' => array( 'type' => 'string', ), ), ), ), 'EncodingType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Encoding-Type', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'KeyMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxUploads' => array( 'type' => 'numeric', 'location' => 'xml', ), 'NextKeyMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextUploadIdMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Prefix' => array( 'type' => 'string', 'location' => 'xml', ), 'UploadIdMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Uploads' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Upload', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Upload', 'properties' => array( 'Initiated' => array( 'type' => 'string', ), 'Initiator' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Key' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'StorageClass' => array( 'type' => 'string', ), 'UploadId' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListObjectVersionsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CommonPrefixes' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'Prefix' => array( 'type' => 'string', ), ), ), ), 'DeleteMarkers' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'DeleteMarker', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'DeleteMarker', 'properties' => array( 'IsLatest' => array( 'type' => 'boolean', ), 'Key' => array( 'type' => 'string', ), 'LastModified' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'EncodingType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Encoding-Type', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'KeyMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxKeys' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Name' => array( 'type' => 'string', 'location' => 'xml', ), 'NextKeyMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'NextVersionIdMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Prefix' => array( 'type' => 'string', 'location' => 'xml', ), 'VersionIdMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Versions' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Version', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Version', 'properties' => array( 'ETag' => array( 'type' => 'string', ), 'IsLatest' => array( 'type' => 'boolean', ), 'Key' => array( 'type' => 'string', ), 'LastModified' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Size' => array( 'type' => 'string', ), 'StorageClass' => array( 'type' => 'string', ), 'VersionId' => array( 'type' => 'string', ), ), ), ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListObjectsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CommonPrefixes' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'Prefix' => array( 'type' => 'string', ), ), ), ), 'Contents' => array( 'type' => 'array', 'location' => 'xml', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'properties' => array( 'ETag' => array( 'type' => 'string', ), 'Key' => array( 'type' => 'string', ), 'LastModified' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'object', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'Size' => array( 'type' => 'numeric', ), 'StorageClass' => array( 'type' => 'string', ), ), ), ), 'EncodingType' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'Encoding-Type', ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Marker' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxKeys' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Name' => array( 'type' => 'string', 'location' => 'xml', ), 'NextMarker' => array( 'type' => 'string', 'location' => 'xml', ), 'Prefix' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'ListPartsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Bucket' => array( 'type' => 'string', 'location' => 'xml', ), 'Initiator' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'IsTruncated' => array( 'type' => 'boolean', 'location' => 'xml', ), 'Key' => array( 'type' => 'string', 'location' => 'xml', ), 'MaxParts' => array( 'type' => 'numeric', 'location' => 'xml', ), 'NextPartNumberMarker' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Owner' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'DisplayName' => array( 'type' => 'string', ), 'ID' => array( 'type' => 'string', ), ), ), 'PartNumberMarker' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Parts' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Part', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'type' => 'object', 'sentAs' => 'Part', 'properties' => array( 'ETag' => array( 'type' => 'string', ), 'LastModified' => array( 'type' => 'string', ), 'PartNumber' => array( 'type' => 'numeric', ), 'Size' => array( 'type' => 'numeric', ), ), ), ), 'StorageClass' => array( 'type' => 'string', 'location' => 'xml', ), 'UploadId' => array( 'type' => 'string', 'location' => 'xml', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketAclOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketCorsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketLifecycleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketLoggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketNotificationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketPolicyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketRequestPaymentOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketTaggingOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketVersioningOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutBucketWebsiteOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'PutObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'Expiration' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-expiration', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'VersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-version-id', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), 'ObjectURL' => array( ), ), ), 'PutObjectAclOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'RestoreObjectOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UploadPartOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ETag' => array( 'type' => 'string', 'location' => 'header', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), 'UploadPartCopyOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ETag' => array( 'type' => 'string', 'location' => 'xml', ), 'LastModified' => array( 'type' => 'string', 'location' => 'xml', ), 'CopySourceVersionId' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-copy-source-version-id', ), 'ServerSideEncryption' => array( 'type' => 'string', 'location' => 'header', 'sentAs' => 'x-amz-server-side-encryption', ), 'RequestId' => array( 'location' => 'header', 'sentAs' => 'x-amz-request-id', ), ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 5, 'max_attempts' => 20, ), 'BucketExists' => array( 'operation' => 'HeadBucket', 'success.type' => 'output', 'ignore_errors' => array( 'NoSuchBucket', ), ), 'BucketNotExists' => array( 'operation' => 'HeadBucket', 'success.type' => 'error', 'success.value' => 'NoSuchBucket', ), 'ObjectExists' => array( 'operation' => 'HeadObject', 'success.type' => 'output', 'ignore_errors' => array( 'NoSuchKey', ), ), ), ); params = $params; $this->client = $client; $this->params['Bucket'] = $bucket; $this->params['Key'] = $key; // If a string is passed, then assume that the download should stream to a file on disk if (is_string($target)) { if (!($target = fopen($target, 'a+'))) { throw new RuntimeException("Unable to open {$target} for writing"); } // Always append to the file fseek($target, 0, SEEK_END); } // Get the metadata and Content-MD5 of the object $this->target = EntityBody::factory($target); } /** * Get the bucket of the download * * @return string */ public function getBucket() { return $this->params['Bucket']; } /** * Get the key of the download * * @return string */ public function getKey() { return $this->params['Key']; } /** * Get the file to which the contents are downloaded * * @return string */ public function getFilename() { return $this->target->getUri(); } /** * Download the remainder of the object from Amazon S3 * * Performs a message integrity check if possible * * @return Model */ public function __invoke() { $command = $this->client->getCommand('HeadObject', $this->params); $this->meta = $command->execute(); if ($this->target->ftell() >= $this->meta['ContentLength']) { return false; } $this->meta['ContentMD5'] = (string) $command->getResponse()->getHeader('Content-MD5'); // Use a ReadLimitEntityBody so that rewinding the stream after an error does not cause the file pointer // to enter an inconsistent state with the data being downloaded $this->params['SaveAs'] = new ReadLimitEntityBody( $this->target, $this->meta['ContentLength'], $this->target->ftell() ); $result = $this->getRemaining(); $this->checkIntegrity(); return $result; } /** * Send the command to get the remainder of the object * * @return Model */ protected function getRemaining() { $current = $this->target->ftell(); $targetByte = $this->meta['ContentLength'] - 1; $this->params['Range'] = "bytes={$current}-{$targetByte}"; // Set the starting offset so that the body is never seeked to before this point in the event of a retry $this->params['SaveAs']->setOffset($current); $command = $this->client->getCommand('GetObject', $this->params); return $command->execute(); } /** * Performs an MD5 message integrity check if possible * * @throws UnexpectedValueException if the message does not validate */ protected function checkIntegrity() { if ($this->target->isReadable() && $expected = $this->meta['ContentMD5']) { $actual = $this->target->getContentMd5(); if ($actual != $expected) { throw new UnexpectedValueException( "Message integrity check failed. Expected {$expected} but got {$actual}." ); } } } } 'ListBuckets', 'GetBucket' => 'ListObjects', 'PutBucket' => 'CreateBucket', // SDK 1.x Aliases 'GetBucketHeaders' => 'HeadBucket', 'GetObjectHeaders' => 'HeadObject', 'SetBucketAcl' => 'PutBucketAcl', 'CreateObject' => 'PutObject', 'DeleteObjects' => 'DeleteMultipleObjects', 'PutObjectCopy' => 'CopyObject', 'SetObjectAcl' => 'PutObjectAcl', 'GetLogs' => 'GetBucketLogging', 'GetVersioningStatus' => 'GetBucketVersioning', 'SetBucketPolicy' => 'PutBucketPolicy', 'CreateBucketNotification' => 'PutBucketNotification', 'GetBucketNotifications' => 'GetBucketNotification', 'CopyPart' => 'UploadPartCopy', 'CreateWebsiteConfig' => 'PutBucketWebsite', 'GetWebsiteConfig' => 'GetBucketWebsite', 'DeleteWebsiteConfig' => 'DeleteBucketWebsite', 'CreateObjectExpirationConfig' => 'PutBucketLifecycle', 'GetObjectExpirationConfig' => 'GetBucketLifecycle', 'DeleteObjectExpirationConfig' => 'DeleteBucketLifecycle', ); /** * @inheritdoc */ protected $directory = __DIR__; /** * Factory method to create a new Amazon S3 client using an array of configuration options. * * @param array|Collection $config Client configuration data * * @return self * @see \Aws\Common\Client\DefaultClient for a list of available configuration options */ public static function factory($config = array()) { $exceptionParser = new S3ExceptionParser(); // Configure the custom exponential backoff plugin for retrying S3 specific errors if (!isset($config[Options::BACKOFF])) { $config[Options::BACKOFF] = self::createBackoffPlugin($exceptionParser); } $config[Options::SIGNATURE] = $signature = self::createSignature($config); $client = ClientBuilder::factory(__NAMESPACE__) ->setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/s3-%s.php' )) ->setExceptionParser($exceptionParser) ->setIteratorsConfig(array( 'more_key' => 'IsTruncated', 'operations' => array( 'ListBuckets', 'ListMultipartUploads' => array( 'limit_param' => 'MaxUploads', 'token_param' => array('KeyMarker', 'UploadIdMarker'), 'token_key' => array('NextKeyMarker', 'NextUploadIdMarker'), ), 'ListObjects' => array( 'limit_param' => 'MaxKeys', 'token_param' => 'Marker', 'token_key' => 'NextMarker', ), 'ListObjectVersions' => array( 'limit_param' => 'MaxKeys', 'token_param' => array('KeyMarker', 'VersionIdMarker'), 'token_key' => array('nextKeyMarker', 'nextVersionIdMarker'), ), 'ListParts' => array( 'limit_param' => 'MaxParts', 'result_key' => 'Parts', 'token_param' => 'PartNumberMarker', 'token_key' => 'NextPartNumberMarker', ), ) )) ->build(); // Use virtual hosted buckets when possible $client->addSubscriber(new BucketStyleListener()); // Ensure that ACP headers are applied when needed $client->addSubscriber(new AcpListener()); // Validate and add required Content-MD5 hashes (e.g. DeleteObjects) $client->addSubscriber(new S3Md5Listener($signature)); // Allow for specifying bodies with file paths and file handles $client->addSubscriber(new UploadBodyListener(array('PutObject', 'UploadPart'))); // Add aliases for some S3 operations $default = CompositeFactory::getDefaultChain($client); $default->add( new AliasFactory($client, self::$commandAliases), 'Guzzle\Service\Command\Factory\ServiceDescriptionFactory' ); $client->setCommandFactory($default); return $client; } /** * Create an Amazon S3 specific backoff plugin * * @param S3ExceptionParser $exceptionParser * * @return BackoffPlugin */ private static function createBackoffPlugin(S3ExceptionParser $exceptionParser) { return new BackoffPlugin( new TruncatedBackoffStrategy(3, new HttpBackoffStrategy(null, new SocketTimeoutChecker( new CurlBackoffStrategy(null, new ExpiredCredentialsChecker($exceptionParser, new ExponentialBackoffStrategy() ) ) ) ) ) ); } /** * Create an appropriate signature based on the configuration settings * * @param $config * * @return S3Signature * @throws InvalidArgumentException */ private static function createSignature($config) { $currentValue = isset($config[Options::SIGNATURE]) ? $config[Options::SIGNATURE] : null; // Use the Amazon S3 signature V4 when the value is set to "v4" or when // the value is not set and the region starts with "cn-". if ($currentValue == 'v4' || (!$currentValue && isset($config['region']) && substr($config['region'], 0, 3) == 'cn-') ) { // Force SignatureV4 for specific regions or if specified in the config $currentValue = new S3SignatureV4('s3'); } elseif (!$currentValue || $currentValue == 's3') { // Use the Amazon S3 signature by default $currentValue = new S3Signature(); } if ($currentValue instanceof S3SignatureInterface) { // A region is require with v4 if ($currentValue instanceof SignatureV4 && !isset($config['region'])) { throw new InvalidArgumentException('A region must be specified ' . 'when using signature version 4'); } return $currentValue; } throw new InvalidArgumentException('The provided signature value is ' . 'not an instance of S3SignatureInterface'); } /** * Determine if a string is a valid name for a DNS compatible Amazon S3 * bucket, meaning the bucket can be used as a subdomain in a URL (e.g., * ".s3.amazonaws.com"). * * @param string $bucket The name of the bucket to check. * * @return bool TRUE if the bucket name is valid or FALSE if it is invalid. */ public static function isValidBucketName($bucket) { $bucketLen = strlen($bucket); if ($bucketLen < 3 || $bucketLen > 63 || // Cannot start or end with a '.' $bucket[0] == '.' || $bucket[$bucketLen - 1] == '.' || // Cannot look like an IP address preg_match('/(\d+\.){3}\d+$/', $bucket) || // Cannot include special characters, must start and end with lower alnum !preg_match('/^[a-z0-9][a-z0-9\-\.]*[a-z0-9]?$/', $bucket) ) { return false; } return true; } /** * Create a pre-signed URL for a request * * @param RequestInterface $request Request to generate the URL for. Use the factory methods of the client to * create this request object * @param int|string|\DateTime $expires The time at which the URL should expire. This can be a Unix timestamp, a * PHP DateTime object, or a string that can be evaluated by strtotime * * @return string * @throws InvalidArgumentException if the request is not associated with this client object */ public function createPresignedUrl(RequestInterface $request, $expires) { if ($request->getClient() !== $this) { throw new InvalidArgumentException('The request object must be associated with the client. Use the ' . '$client->get(), $client->head(), $client->post(), $client->put(), etc. methods when passing in a ' . 'request object'); } return $this->signature->createPresignedUrl($request, $this->credentials, $expires); } /** * Returns the URL to an object identified by its bucket and key. If an expiration time is provided, the URL will * be signed and set to expire at the provided time. * * @param string $bucket The name of the bucket where the object is located * @param string $key The key of the object * @param mixed $expires The time at which the URL should expire * @param array $args Arguments to the GetObject command. Additionally you can specify a "Scheme" if you would * like the URL to use a different scheme than what the client is configured to use * * @return string The URL to the object */ public function getObjectUrl($bucket, $key, $expires = null, array $args = array()) { $command = $this->getCommand('GetObject', $args + array('Bucket' => $bucket, 'Key' => $key)); if ($command->hasKey('Scheme')) { $scheme = $command['Scheme']; $request = $command->remove('Scheme')->prepare()->setScheme($scheme)->setPort(null); } else { $request = $command->prepare(); } return $expires ? $this->createPresignedUrl($request, $expires) : $request->getUrl(); } /** * Helper used to clear the contents of a bucket. Use the {@see ClearBucket} object directly * for more advanced options and control. * * @param string $bucket Name of the bucket to clear. * * @return int Returns the number of deleted keys */ public function clearBucket($bucket) { $clear = new ClearBucket($this, $bucket); return $clear->clear(); } /** * Determines whether or not a bucket exists by name * * @param string $bucket The name of the bucket * @param bool $accept403 Set to true if 403s are acceptable * @param array $options Additional options to add to the executed command * * @return bool */ public function doesBucketExist($bucket, $accept403 = true, array $options = array()) { return $this->checkExistenceWithCommand( $this->getCommand('HeadBucket', array_merge($options, array( 'Bucket' => $bucket ))), $accept403 ); } /** * Determines whether or not an object exists by name * * @param string $bucket The name of the bucket * @param string $key The key of the object * @param array $options Additional options to add to the executed command * * @return bool */ public function doesObjectExist($bucket, $key, array $options = array()) { return $this->checkExistenceWithCommand( $this->getCommand('HeadObject', array_merge($options, array( 'Bucket' => $bucket, 'Key' => $key ))) ); } /** * Determines whether or not a bucket policy exists for a bucket * * @param string $bucket The name of the bucket * @param array $options Additional options to add to the executed command * * @return bool */ public function doesBucketPolicyExist($bucket, array $options = array()) { return $this->checkExistenceWithCommand( $this->getCommand('GetBucketPolicy', array_merge($options, array( 'Bucket' => $bucket ))) ); } /** * Raw URL encode a key and allow for '/' characters * * @param string $key Key to encode * * @return string Returns the encoded key */ public static function encodeKey($key) { return str_replace('%2F', '/', rawurlencode($key)); } /** * Explode a prefixed key into an array of values * * @param string $key Key to explode * * @return array Returns the exploded */ public static function explodeKey($key) { // Remove a leading slash if one is found return explode('/', $key && $key[0] == '/' ? substr($key, 1) : $key); } /** * Register the Amazon S3 stream wrapper and associates it with this client object * * @return self */ public function registerStreamWrapper() { StreamWrapper::register($this); return $this; } /** * Upload a file, stream, or string to a bucket. If the upload size exceeds the specified threshold, the upload * will be performed using parallel multipart uploads. * * @param string $bucket Bucket to upload the object * @param string $key Key of the object * @param mixed $body Object data to upload. Can be a Guzzle\Http\EntityBodyInterface, stream resource, or * string of data to upload. * @param string $acl ACL to apply to the object * @param array $options Custom options used when executing commands: * - params: Custom parameters to use with the upload. The parameters must map to a PutObject * or InitiateMultipartUpload operation parameters. * - min_part_size: Minimum size to allow for each uploaded part when performing a multipart upload. * - concurrency: Maximum number of concurrent multipart uploads. * - before_upload: Callback to invoke before each multipart upload. The callback will receive a * Guzzle\Common\Event object with context. * * @see Aws\S3\Model\MultipartUpload\UploadBuilder for more options and customization * @return \Guzzle\Service\Resource\Model Returns the modeled result of the performed operation */ public function upload($bucket, $key, $body, $acl = 'private', array $options = array()) { $body = EntityBody::factory($body); $options = Collection::fromConfig(array_change_key_case($options), array( 'min_part_size' => AbstractMulti::MIN_PART_SIZE, 'params' => array(), 'concurrency' => $body->getWrapper() == 'plainfile' ? 3 : 1 )); if ($body->getSize() < $options['min_part_size']) { // Perform a simple PutObject operation return $this->putObject(array( 'Bucket' => $bucket, 'Key' => $key, 'Body' => $body, 'ACL' => $acl ) + $options['params']); } // Perform a multipart upload if the file is large enough $transfer = UploadBuilder::newInstance() ->setBucket($bucket) ->setKey($key) ->setMinPartSize($options['min_part_size']) ->setConcurrency($options['concurrency']) ->setClient($this) ->setSource($body) ->setTransferOptions($options->toArray()) ->addOptions($options['params']) ->setOption('ACL', $acl) ->build() ->upload(); if ($options['before_upload']) { $transfer->getEventDispatcher()->addListener( AbstractTransfer::BEFORE_PART_UPLOAD, $options['before_upload'] ); } return $transfer; } /** * Recursively uploads all files in a given directory to a given bucket. * * @param string $directory Full path to a directory to upload * @param string $bucket Name of the bucket * @param string $keyPrefix Virtual directory key prefix to add to each upload * @param array $options Associative array of upload options * - params: Array of parameters to use with each PutObject operation performed during the transfer * - base_dir: Base directory to remove from each object key * - force: Set to true to upload every file, even if the file is already in Amazon S3 and has not changed * - concurrency: Maximum number of parallel uploads (defaults to 10) * - debug: Set to true or an fopen resource to enable debug mode to print information about each upload * - multipart_upload_size: When the size of a file exceeds this value, the file will be uploaded using a * multipart upload. * * @see Aws\S3\S3Sync\S3Sync for more options and customization */ public function uploadDirectory($directory, $bucket, $keyPrefix = null, array $options = array()) { $options = Collection::fromConfig($options, array('base_dir' => $directory)); $builder = $options['builder'] ?: UploadSyncBuilder::getInstance(); $builder->uploadFromDirectory($directory) ->setClient($this) ->setBucket($bucket) ->setKeyPrefix($keyPrefix) ->setConcurrency($options['concurrency'] ?: 5) ->setBaseDir($options['base_dir']) ->force($options['force']) ->setOperationParams($options['params'] ?: array()) ->enableDebugOutput($options['debug']); if ($options->hasKey('multipart_upload_size')) { $builder->setMultipartUploadSize($options['multipart_upload_size']); } $builder->build()->transfer(); } /** * Downloads a bucket to the local filesystem * * @param string $directory Directory to download to * @param string $bucket Bucket to download from * @param string $keyPrefix Only download objects that use this key prefix * @param array $options Associative array of download options * - params: Array of parameters to use with each GetObject operation performed during the transfer * - base_dir: Base directory to remove from each object key when storing in the local filesystem * - force: Set to true to download every file, even if the file is already on the local filesystem and has not * changed * - concurrency: Maximum number of parallel downloads (defaults to 10) * - debug: Set to true or a fopen resource to enable debug mode to print information about each download * - allow_resumable: Set to true to allow previously interrupted downloads to be resumed using a Range GET */ public function downloadBucket($directory, $bucket, $keyPrefix = '', array $options = array()) { $options = new Collection($options); $builder = $options['builder'] ?: DownloadSyncBuilder::getInstance(); $builder->setDirectory($directory) ->setClient($this) ->setBucket($bucket) ->setKeyPrefix($keyPrefix) ->setConcurrency($options['concurrency'] ?: 10) ->setBaseDir($options['base_dir']) ->force($options['force']) ->setOperationParams($options['params'] ?: array()) ->enableDebugOutput($options['debug']); if ($options['allow_resumable']) { $builder->allowResumableDownloads(); } $builder->build()->transfer(); } /** * Deletes objects from Amazon S3 that match the result of a ListObjects operation. For example, this allows you * to do things like delete all objects that match a specific key prefix. * * @param string $bucket Bucket that contains the object keys * @param string $prefix Optionally delete only objects under this key prefix * @param string $regex Delete only objects that match this regex * @param array $options Options used when deleting the object: * - before_delete: Callback to invoke before each delete. The callback will receive a * Guzzle\Common\Event object with context. * * @see Aws\S3\S3Client::listObjects * @see Aws\S3\Model\ClearBucket For more options or customization * @return int Returns the number of deleted keys * @throws RuntimeException if no prefix and no regex is given */ public function deleteMatchingObjects($bucket, $prefix = '', $regex = '', array $options = array()) { if (!$prefix && !$regex) { throw new RuntimeException('A prefix or regex is required, or use S3Client::clearBucket().'); } $clear = new ClearBucket($this, $bucket); $iterator = $this->getIterator('ListObjects', array('Bucket' => $bucket, 'Prefix' => $prefix)); if ($regex) { $iterator = new FilterIterator($iterator, function ($current) use ($regex) { return preg_match($regex, $current['Key']); }); } $clear->setIterator($iterator); if (isset($options['before_delete'])) { $clear->getEventDispatcher()->addListener(ClearBucket::BEFORE_CLEAR, $options['before_delete']); } return $clear->clear(); } /** * Determines whether or not a resource exists using a command * * @param CommandInterface $command Command used to poll for the resource * @param bool $accept403 Set to true if 403s are acceptable * * @return bool * @throws S3Exception|\Exception if there is an unhandled exception */ protected function checkExistenceWithCommand(CommandInterface $command, $accept403 = false) { try { $command->execute(); $exists = true; } catch (AccessDeniedException $e) { $exists = (bool) $accept403; } catch (S3Exception $e) { $exists = false; if ($e->getResponse()->getStatusCode() >= 500) { // @codeCoverageIgnoreStart throw $e; // @codeCoverageIgnoreEnd } } return $exists; } } 'onCommandAfterPrepare'); } public function __construct(S3SignatureInterface $signature) { $this->signature = $signature; } public function onCommandAfterPrepare(Event $event) { $command = $event['command']; $operation = $command->getOperation(); if ($operation->getData('contentMd5')) { // Add the MD5 if it is required for all signers $this->addMd5($command); } elseif ($operation->hasParam('ContentMD5')) { $value = $command['ContentMD5']; // Add a computed MD5 if the parameter is set to true or if // not using Signature V4 and the value is not set (null). if ($value === true || ($value === null && !($this->signature instanceof SignatureV4)) ) { $this->addMd5($command); } } } private function addMd5(CommandInterface $command) { $request = $command->getRequest(); if ($body = $request->getBody()) { if (false === ($md5 = $body->getContentMd5(true, true))) { throw new RuntimeException('Unable to add a MD5 checksum'); } $request->setHeader('Content-MD5', $md5); } } } signableQueryString); // Add the security token header if one is being used by the credentials if ($token = $credentials->getSecurityToken()) { $request->setHeader('x-amz-security-token', $token); } // Add a date header if one is not set if (!$request->hasHeader('date') && !$request->hasHeader('x-amz-date')) { $request->setHeader('Date', gmdate(\DateTime::RFC2822)); } $stringToSign = $this->createCanonicalizedString($request); $request->getParams()->set('aws.string_to_sign', $stringToSign); $request->setHeader( 'Authorization', 'AWS ' . $credentials->getAccessKeyId() . ':' . $this->signString($stringToSign, $credentials) ); } public function createPresignedUrl( RequestInterface $request, CredentialsInterface $credentials, $expires ) { if ($expires instanceof \DateTime) { $expires = $expires->getTimestamp(); } elseif (!is_numeric($expires)) { $expires = strtotime($expires); } // Operate on a clone of the request, so the original is not altered $request = clone $request; // URL encoding already occurs in the URI template expansion. Undo that and encode using the same encoding as // GET object, PUT object, etc. $path = S3Client::encodeKey(rawurldecode($request->getPath())); $request->setPath($path); // Make sure to handle temporary credentials if ($token = $credentials->getSecurityToken()) { $request->setHeader('x-amz-security-token', $token); $request->getQuery()->set('x-amz-security-token', $token); } // Set query params required for pre-signed URLs $request->getQuery() ->set('AWSAccessKeyId', $credentials->getAccessKeyId()) ->set('Expires', $expires) ->set('Signature', $this->signString( $this->createCanonicalizedString($request, $expires), $credentials )); return $request->getUrl(); } public function signString($string, CredentialsInterface $credentials) { return base64_encode(hash_hmac('sha1', $string, $credentials->getSecretKey(), true)); } public function createCanonicalizedString(RequestInterface $request, $expires = null) { $buffer = $request->getMethod() . "\n"; // Add the interesting headers foreach ($this->signableHeaders as $header) { $buffer .= (string) $request->getHeader($header) . "\n"; } // Choose dates from left to right based on what's set $date = $expires ?: (string) $request->getHeader('date'); $buffer .= "{$date}\n" . $this->createCanonicalizedAmzHeaders($request) . $this->createCanonicalizedResource($request); return $buffer; } /** * Create a canonicalized AmzHeaders string for a signature. * * @param RequestInterface $request Request from which to gather headers * * @return string Returns canonicalized AMZ headers. */ private function createCanonicalizedAmzHeaders(RequestInterface $request) { $headers = array(); foreach ($request->getHeaders(true) as $header) { /** @var $header \Guzzle\Http\Message\Header */ $name = strtolower($header->getName()); if (strpos($name, 'x-amz-') === 0) { $value = trim((string) $header); if ($value || $value === '0') { $headers[$name] = $name . ':' . $value; } } } if (empty($headers)) { return ''; } ksort($headers); return implode("\n", $headers) . "\n"; } /** * Create a canonicalized resource for a request * * @param RequestInterface $request Request for the resource * * @return string */ private function createCanonicalizedResource(RequestInterface $request) { $buffer = $request->getParams()->get('s3.resource'); // When sending a raw HTTP request (e.g. $client->get()) if (null === $buffer) { $bucket = $request->getParams()->get('bucket') ?: $this->parseBucketName($request); // Use any specified bucket name, the parsed bucket name, or no bucket name when interacting with GetService $buffer = $bucket ? "/{$bucket}" : ''; // Remove encoding from the path and use the S3 specific encoding $path = S3Client::encodeKey(rawurldecode($request->getPath())); // if the bucket was path style, then ensure that the bucket wasn't duplicated in the resource $buffer .= preg_replace("#^/{$bucket}/{$bucket}#", "/{$bucket}", $path); } // Remove double slashes $buffer = str_replace('//', '/', $buffer); // Add sub resource parameters $query = $request->getQuery(); $first = true; foreach ($this->signableQueryString as $key) { if ($query->hasKey($key)) { $value = $query[$key]; $buffer .= $first ? '?' : '&'; $first = false; $buffer .= $key; // Don't add values for sub-resources if ($value !== '' && $value !== QueryString::BLANK) { $buffer .= "={$value}"; } } } return $buffer; } /** * Parse the bucket name from a request object * * @param RequestInterface $request Request to parse * * @return string */ private function parseBucketName(RequestInterface $request) { $baseUrl = Url::factory($request->getClient()->getBaseUrl()); $baseHost = $baseUrl->getHost(); $host = $request->getHost(); if (strpos($host, $baseHost) === false) { // Does not contain the base URL, so it's either a redirect, CNAME, or using a different region $baseHost = ''; // For every known S3 host, check if that host is present on the request $regions = $request->getClient()->getDescription()->getData('regions'); foreach ($regions as $region) { if (strpos($host, $region['hostname']) !== false) { // This host matches the request host. Tells use the region and endpoint-- we can derive the bucket $baseHost = $region['hostname']; break; } } // If no matching base URL was found, then assume that this is a CNAME, and the CNAME is the bucket if (!$baseHost) { return $host; } } // Remove the baseURL from the host of the request to attempt to determine the bucket name return trim(str_replace($baseHost, '', $request->getHost()), ' .'); } } getBody()) { $request->setHeader('X-Amz-Content-Sha256', EntityBody::getHash($request->getBody(), 'sha256')); } else { $request->setHeader('X-Amz-Content-Sha256', hash('sha256', '')); } parent::signRequest($request, $credentials); } public function createPresignedUrl( RequestInterface $request, CredentialsInterface $credentials, $expires ) { $request = clone $request; // Make sure to handle temporary credentials if ($token = $credentials->getSecurityToken()) { $request->setHeader('X-Amz-Security-Token', $token); $request->getQuery()->set('X-Amz-Security-Token', $token); } $this->moveHeadersToQuery($request); $httpDate = $request->getQuery()->get('X-Amz-Date'); $scopeDate = substr($httpDate, 0, 8); $scope = "{$scopeDate}/{$this->regionName}/s3/aws4_request"; $credential = $credentials->getAccessKeyId() . '/' . $scope; $this->addQueryStringValues($request, $credential, $this->convertExpires($expires)); $context = $this->createSigningContext($request, 'UNSIGNED-PAYLOAD'); $signingKey = $this->getSigningKey( $scopeDate, $this->regionName, $this->serviceName, $credentials->getSecretKey() ); $stringToSign = "AWS4-HMAC-SHA256\n{$httpDate}\n{$scope}\n" . hash('sha256', $context['canonical_request']); $request->getQuery()->set( 'X-Amz-Signature', hash_hmac('sha256', $stringToSign, $signingKey) ); return $request->getUrl(); } /** * Overrides the parent class to prevent the removal of dot-segments */ protected function normalizePath(RequestInterface $request) { return '/' . ltrim($request->getPath(), '/'); } private function convertExpires($expires) { if ($expires instanceof \DateTime) { $expires = $expires->getTimestamp(); } elseif (!is_numeric($expires)) { $expires = strtotime($expires); } $duration = $expires - time(); // Ensure that the duration of the signature is not longer than a week if ($duration > 604800) { throw new InvalidArgumentException('The expiration date of an ' . 'Amazon S3 presigned URL using signature version 4 must be ' . 'less than one week.'); } return $duration; } private function moveHeadersToQuery(RequestInterface $request) { $query = array('X-Amz-Date' => gmdate('Ymd\THis\Z', $this->getTimestamp())); foreach ($request->getHeaders() as $name => $header) { if (substr($name, 0, 5) == 'x-amz') { $query[$header->getName()] = (string) $header; } if ($name != 'host') { $request->removeHeader($name); } } $request->getQuery()->overwriteWith($query); } private function addQueryStringValues( RequestInterface $request, $credential, $expires ) { // Set query params required for pre-signed URLs $request->getQuery() ->set('X-Amz-Algorithm', 'AWS4-HMAC-SHA256') ->set('X-Amz-Credential', $credential) ->set('X-Amz-SignedHeaders', 'Host') ->set('X-Amz-Expires', $expires); } } setNext($next); } } /** * {@inheridoc} */ public function makesDecision() { return true; } /** * {@inheritdoc} */ protected function getDelay( $retries, RequestInterface $request, Response $response = null, HttpException $e = null ) { if ($response && $response->getStatusCode() == 400 && strpos($response->getBody(), self::ERR) ) { // Check if the request is sending a local file, and if so, clear the stat cache and recalculate the size. if ($request instanceof EntityEnclosingRequestInterface) { if ($request->getBody()->getWrapper() == 'plainfile') { $filename = $request->getBody()->getUri(); // Clear the cache so that we send accurate file sizes clearstatcache(true, $filename); $length = filesize($filename); $request->getBody()->setSize($length); $request->setHeader('Content-Length', $length); } } return true; } } } /" files with PHP streams, supporting "r", "w", "a", "x". * * # Supported stream related PHP functions: * - fopen, fclose, fread, fwrite, fseek, ftell, feof, fflush * - opendir, closedir, readdir, rewinddir * - copy, rename, unlink * - mkdir, rmdir, rmdir (recursive) * - file_get_contents, file_put_contents * - file_exists, filesize, is_file, is_dir * * # Opening "r" (read only) streams: * * Read only streams are truly streaming by default and will not allow you to seek. This is because data * read from the stream is not kept in memory or on the local filesystem. You can force a "r" stream to be seekable * by setting the "seekable" stream context option true. This will allow true streaming of data from Amazon S3, but * will maintain a buffer of previously read bytes in a 'php://temp' stream to allow seeking to previously read bytes * from the stream. * * You may pass any GetObject parameters as 's3' stream context options. These options will affect how the data is * downloaded from Amazon S3. * * # Opening "w" and "x" (write only) streams: * * Because Amazon S3 requires a Content-Length header, write only streams will maintain a 'php://temp' stream to buffer * data written to the stream until the stream is flushed (usually by closing the stream with fclose). * * You may pass any PutObject parameters as 's3' stream context options. These options will affect how the data is * uploaded to Amazon S3. * * When opening an "x" stream, the file must exist on Amazon S3 for the stream to open successfully. * * # Opening "a" (write only append) streams: * * Similar to "w" streams, opening append streams requires that the data be buffered in a "php://temp" stream. Append * streams will attempt to download the contents of an object in Amazon S3, seek to the end of the object, then allow * you to append to the contents of the object. The data will then be uploaded using a PutObject operation when the * stream is flushed (usually with fclose). * * You may pass any GetObject and/or PutObject parameters as 's3' stream context options. These options will affect how * the data is downloaded and uploaded from Amazon S3. * * Stream context options: * * - "seekable": Set to true to create a seekable "r" (read only) stream by using a php://temp stream buffer * - "throw_exceptions": Set to true to throw exceptions instead of trigger_errors * - For "unlink" only: Any option that can be passed to the DeleteObject operation */ class StreamWrapper { /** * @var resource|null Stream context (this is set by PHP when a context is used) */ public $context; /** * @var S3Client Client used to send requests */ protected static $client; /** * @var string Mode the stream was opened with */ protected $mode; /** * @var EntityBody Underlying stream resource */ protected $body; /** * @var array Current parameters to use with the flush operation */ protected $params; /** * @var ListObjectsIterator Iterator used with opendir() and subsequent readdir() calls */ protected $objectIterator; /** * @var string The bucket that was opened when opendir() was called */ protected $openedBucket; /** * @var string The prefix of the bucket that was opened with opendir() */ protected $openedBucketPrefix; /** * @var array The next key to retrieve when using a directory iterator. Helps for fast directory traversal. */ protected static $nextStat = array(); /** * Register the 's3://' stream wrapper * * @param S3Client $client Client to use with the stream wrapper */ public static function register(S3Client $client) { if (in_array('s3', stream_get_wrappers())) { stream_wrapper_unregister('s3'); } stream_wrapper_register('s3', __CLASS__, STREAM_IS_URL); self::$client = $client; } /** * Close the stream */ public function stream_close() { $this->body = null; } /** * @param string $path * @param string $mode * @param int $options * @param string $opened_path * * @return bool */ public function stream_open($path, $mode, $options, &$opened_path) { // We don't care about the binary flag $this->mode = $mode = rtrim($mode, 'bt'); $this->params = $params = $this->getParams($path); $errors = array(); if (!$params['Key']) { $errors[] = 'Cannot open a bucket. You must specify a path in the form of s3://bucket/key'; } if (strpos($mode, '+')) { $errors[] = 'The Amazon S3 stream wrapper does not allow simultaneous reading and writing.'; } if (!in_array($mode, array('r', 'w', 'a', 'x'))) { $errors[] = "Mode not supported: {$mode}. Use one 'r', 'w', 'a', or 'x'."; } // When using mode "x" validate if the file exists before attempting to read if ($mode == 'x' && self::$client->doesObjectExist($params['Bucket'], $params['Key'], $this->getOptions())) { $errors[] = "{$path} already exists on Amazon S3"; } if (!$errors) { if ($mode == 'r') { $this->openReadStream($params, $errors); } elseif ($mode == 'a') { $this->openAppendStream($params, $errors); } else { $this->openWriteStream($params, $errors); } } return $errors ? $this->triggerError($errors) : true; } /** * @return bool */ public function stream_eof() { return $this->body->feof(); } /** * @return bool */ public function stream_flush() { if ($this->mode == 'r') { return false; } $this->body->rewind(); $params = $this->params; $params['Body'] = $this->body; // Attempt to guess the ContentType of the upload based on the // file extension of the key if (!isset($params['ContentType']) && ($type = Mimetypes::getInstance()->fromFilename($params['Key'])) ) { $params['ContentType'] = $type; } try { self::$client->putObject($params); return true; } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } } /** * Read data from the underlying stream * * @param int $count Amount of bytes to read * * @return string */ public function stream_read($count) { return $this->body->read($count); } /** * Seek to a specific byte in the stream * * @param int $offset Seek offset * @param int $whence Whence (SEEK_SET, SEEK_CUR, SEEK_END) * * @return bool */ public function stream_seek($offset, $whence = SEEK_SET) { return $this->body->seek($offset, $whence); } /** * Get the current position of the stream * * @return int Returns the current position in the stream */ public function stream_tell() { return $this->body->ftell(); } /** * Write data the to the stream * * @param string $data * * @return int Returns the number of bytes written to the stream */ public function stream_write($data) { return $this->body->write($data); } /** * Delete a specific object * * @param string $path * @return bool */ public function unlink($path) { try { $this->clearStatInfo($path); self::$client->deleteObject($this->getParams($path)); return true; } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } } /** * @return array */ public function stream_stat() { $stat = fstat($this->body->getStream()); // Add the size of the underlying stream if it is known if ($this->mode == 'r' && $this->body->getSize()) { $stat[7] = $stat['size'] = $this->body->getSize(); } return $stat; } /** * Provides information for is_dir, is_file, filesize, etc. Works on buckets, keys, and prefixes * * @param string $path * @param int $flags * * @return array Returns an array of stat data * @link http://www.php.net/manual/en/streamwrapper.url-stat.php */ public function url_stat($path, $flags) { // Check if this path is in the url_stat cache if (isset(self::$nextStat[$path])) { return self::$nextStat[$path]; } $parts = $this->getParams($path); if (!$parts['Key']) { // Stat "directories": buckets, or "s3://" if (!$parts['Bucket'] || self::$client->doesBucketExist($parts['Bucket'])) { return $this->formatUrlStat($path); } else { return $this->triggerError("File or directory not found: {$path}", $flags); } } try { try { $result = self::$client->headObject($parts)->toArray(); if (substr($parts['Key'], -1, 1) == '/' && $result['ContentLength'] == 0) { // Return as if it is a bucket to account for console bucket objects (e.g., zero-byte object "foo/") return $this->formatUrlStat($path); } else { // Attempt to stat and cache regular object return $this->formatUrlStat($result); } } catch (NoSuchKeyException $e) { // Maybe this isn't an actual key, but a prefix. Do a prefix listing of objects to determine. $result = self::$client->listObjects(array( 'Bucket' => $parts['Bucket'], 'Prefix' => rtrim($parts['Key'], '/') . '/', 'MaxKeys' => 1 )); if (!$result['Contents'] && !$result['CommonPrefixes']) { return $this->triggerError("File or directory not found: {$path}", $flags); } // This is a directory prefix return $this->formatUrlStat($path); } } catch (\Exception $e) { return $this->triggerError($e->getMessage(), $flags); } } /** * Support for mkdir(). * * @param string $path Directory which should be created. * @param int $mode Permissions. 700-range permissions map to ACL_PUBLIC. 600-range permissions map to * ACL_AUTH_READ. All other permissions map to ACL_PRIVATE. Expects octal form. * @param int $options A bitwise mask of values, such as STREAM_MKDIR_RECURSIVE. (unused) * * @return bool * @link http://www.php.net/manual/en/streamwrapper.mkdir.php */ public function mkdir($path, $mode, $options) { $params = $this->getParams($path); $this->clearStatInfo($path); if (!$params['Bucket'] || $params['Key']) { return false; } try { if (!isset($params['ACL'])) { $mode = decoct($mode); if ($mode >= 700 and $mode <= 799) { $params['ACL'] = 'public-read'; } elseif ($mode >= 600 && $mode <= 699) { $params['ACL'] = 'authenticated-read'; } else { $params['ACL'] = 'private'; } } self::$client->createBucket($params); return true; } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } } /** * Remove a bucket from Amazon S3 * * @param string $path the directory path * * @return bool true if directory was successfully removed * @link http://www.php.net/manual/en/streamwrapper.rmdir.php */ public function rmdir($path) { $params = $this->getParams($path); if (!$params['Bucket']) { return $this->triggerError('You cannot delete s3://. Please specify a bucket.'); } elseif ($params['Key']) { return $this->triggerError('rmdir() only supports bucket deletion'); } try { self::$client->deleteBucket(array('Bucket' => $params['Bucket'])); $this->clearStatInfo($path); return true; } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } } /** * Support for opendir(). * * @param string $path The path to the directory (e.g. "s3://dir[]") * @param string $options Whether or not to enforce safe_mode (0x04). Unused. * * @return bool true on success * @see http://www.php.net/manual/en/function.opendir.php */ public function dir_opendir($path, $options) { // Reset the cache $this->clearStatInfo(); $params = $this->getParams($path); $delimiter = $this->getOption('delimiter'); if ($delimiter === null) { $delimiter = '/'; } if ($params['Key']) { $params['Key'] = rtrim($params['Key'], $delimiter) . $delimiter; } $this->openedBucket = $params['Bucket']; $this->openedBucketPrefix = $params['Key']; $operationParams = array('Bucket' => $params['Bucket'], 'Prefix' => $params['Key']); if ($delimiter) { $operationParams['Delimiter'] = $delimiter; } $this->objectIterator = self::$client->getIterator('ListObjects', $operationParams, array( 'return_prefixes' => true, 'sort_results' => true )); $this->objectIterator->next(); return true; } /** * Close the directory listing handles * * @return bool true on success */ public function dir_closedir() { $this->objectIterator = null; return true; } /** * This method is called in response to rewinddir() * * @return boolean true on success */ public function dir_rewinddir() { $this->clearStatInfo(); $this->objectIterator->rewind(); return true; } /** * This method is called in response to readdir() * * @return string Should return a string representing the next filename, or false if there is no next file. * * @link http://www.php.net/manual/en/function.readdir.php */ public function dir_readdir() { $result = false; if ($this->objectIterator->valid()) { $current = $this->objectIterator->current(); if (isset($current['Prefix'])) { // Include "directories". Be sure to strip a trailing "/" on prefixes. $prefix = rtrim($current['Prefix'], '/'); $result = str_replace($this->openedBucketPrefix, '', $prefix); $key = "s3://{$this->openedBucket}/{$prefix}"; $stat = $this->formatUrlStat($prefix); } else { // Remove the prefix from the result to emulate other stream wrappers $result = str_replace($this->openedBucketPrefix, '', $current['Key']); $key = "s3://{$this->openedBucket}/{$current['Key']}"; $stat = $this->formatUrlStat($current); } // Cache the object data for quick url_stat lookups used with RecursiveDirectoryIterator self::$nextStat = array($key => $stat); $this->objectIterator->next(); } return $result; } /** * Called in response to rename() to rename a file or directory. Currently only supports renaming objects. * * @param string $path_from the path to the file to rename * @param string $path_to the new path to the file * * @return bool true if file was successfully renamed * @link http://www.php.net/manual/en/function.rename.php */ public function rename($path_from, $path_to) { $partsFrom = $this->getParams($path_from); $partsTo = $this->getParams($path_to); $this->clearStatInfo($path_from); $this->clearStatInfo($path_to); if (!$partsFrom['Key'] || !$partsTo['Key']) { return $this->triggerError('The Amazon S3 stream wrapper only supports copying objects'); } try { // Copy the object and allow overriding default parameters if desired, but by default copy metadata self::$client->copyObject($this->getOptions() + array( 'Bucket' => $partsTo['Bucket'], 'Key' => $partsTo['Key'], 'CopySource' => '/' . $partsFrom['Bucket'] . '/' . rawurlencode($partsFrom['Key']), 'MetadataDirective' => 'COPY' )); // Delete the original object self::$client->deleteObject(array( 'Bucket' => $partsFrom['Bucket'], 'Key' => $partsFrom['Key'] ) + $this->getOptions()); } catch (\Exception $e) { return $this->triggerError($e->getMessage()); } return true; } /** * Cast the stream to return the underlying file resource * * @param int $cast_as STREAM_CAST_FOR_SELECT or STREAM_CAST_AS_STREAM * * @return resource */ public function stream_cast($cast_as) { return $this->body->getStream(); } /** * Get the stream context options available to the current stream * * @return array */ protected function getOptions() { $context = $this->context ?: stream_context_get_default(); $options = stream_context_get_options($context); return isset($options['s3']) ? $options['s3'] : array(); } /** * Get a specific stream context option * * @param string $name Name of the option to retrieve * * @return mixed|null */ protected function getOption($name) { $options = $this->getOptions(); return isset($options[$name]) ? $options[$name] : null; } /** * Get the bucket and key from the passed path (e.g. s3://bucket/key) * * @param string $path Path passed to the stream wrapper * * @return array Hash of 'Bucket', 'Key', and custom params */ protected function getParams($path) { $parts = explode('/', substr($path, 5), 2); $params = $this->getOptions(); unset($params['seekable']); unset($params['throw_exceptions']); return array( 'Bucket' => $parts[0], 'Key' => isset($parts[1]) ? $parts[1] : null ) + $params; } /** * Serialize and sign a command, returning a request object * * @param CommandInterface $command Command to sign * * @return RequestInterface */ protected function getSignedRequest($command) { $request = $command->prepare(); $request->dispatch('request.before_send', array('request' => $request)); return $request; } /** * Initialize the stream wrapper for a read only stream * * @param array $params Operation parameters * @param array $errors Any encountered errors to append to * * @return bool */ protected function openReadStream(array $params, array &$errors) { // Create the command and serialize the request $request = $this->getSignedRequest(self::$client->getCommand('GetObject', $params)); // Create a stream that uses the EntityBody object $factory = $this->getOption('stream_factory') ?: new PhpStreamRequestFactory(); $this->body = $factory->fromRequest($request, array(), array('stream_class' => 'Guzzle\Http\EntityBody')); // Wrap the body in a caching entity body if seeking is allowed if ($this->getOption('seekable')) { $this->body = new CachingEntityBody($this->body); } return true; } /** * Initialize the stream wrapper for a write only stream * * @param array $params Operation parameters * @param array $errors Any encountered errors to append to * * @return bool */ protected function openWriteStream(array $params, array &$errors) { $this->body = new EntityBody(fopen('php://temp', 'r+')); } /** * Initialize the stream wrapper for an append stream * * @param array $params Operation parameters * @param array $errors Any encountered errors to append to * * @return bool */ protected function openAppendStream(array $params, array &$errors) { try { // Get the body of the object $this->body = self::$client->getObject($params)->get('Body'); $this->body->seek(0, SEEK_END); } catch (S3Exception $e) { // The object does not exist, so use a simple write stream $this->openWriteStream($params, $errors); } return true; } /** * Trigger one or more errors * * @param string|array $errors Errors to trigger * @param mixed $flags If set to STREAM_URL_STAT_QUIET, then no error or exception occurs * * @return bool Returns false * @throws RuntimeException if throw_errors is true */ protected function triggerError($errors, $flags = null) { if ($flags != STREAM_URL_STAT_QUIET) { if ($this->getOption('throw_exceptions')) { throw new RuntimeException(implode("\n", (array) $errors)); } else { trigger_error(implode("\n", (array) $errors), E_USER_WARNING); } } return false; } /** * Prepare a url_stat result array * * @param string|array $result Data to add * * @return array Returns the modified url_stat result */ protected function formatUrlStat($result = null) { static $statTemplate = array( 0 => 0, 'dev' => 0, 1 => 0, 'ino' => 0, 2 => 0, 'mode' => 0, 3 => 0, 'nlink' => 0, 4 => 0, 'uid' => 0, 5 => 0, 'gid' => 0, 6 => -1, 'rdev' => -1, 7 => 0, 'size' => 0, 8 => 0, 'atime' => 0, 9 => 0, 'mtime' => 0, 10 => 0, 'ctime' => 0, 11 => -1, 'blksize' => -1, 12 => -1, 'blocks' => -1, ); $stat = $statTemplate; // Determine what type of data is being cached if (!$result || is_string($result)) { // Directory with 0777 access - see "man 2 stat". $stat['mode'] = $stat[2] = 0040777; } elseif (is_array($result) && isset($result['LastModified'])) { // ListObjects or HeadObject result $stat['mtime'] = $stat[9] = $stat['ctime'] = $stat[10] = strtotime($result['LastModified']); $stat['size'] = $stat[7] = (isset($result['ContentLength']) ? $result['ContentLength'] : $result['Size']); // Regular file with 0777 access - see "man 2 stat". $stat['mode'] = $stat[2] = 0100777; } else { $stat['mode'] = $stat[2] = 0100777; } return $stat; } /** * Clear the next stat result from the cache * * @param string $path If a path is specific, clearstatcache() will be called */ protected function clearStatInfo($path = null) { self::$nextStat = array(); if ($path) { clearstatcache(true, $path); } } } options = Collection::fromConfig( $options, array('concurrency' => 10), array('client', 'bucket', 'iterator', 'source_converter') ); $this->init(); } public static function getAllEvents() { return array(self::BEFORE_TRANSFER, self::AFTER_TRANSFER); } /** * Begin transferring files */ public function transfer() { // Pull out chunks of uploads to upload in parallel $iterator = new ChunkedIterator($this->options['iterator'], $this->options['concurrency']); foreach ($iterator as $files) { $this->transferFiles($files); } } /** * Create a command or special transfer action for the * * @param \SplFileInfo $file File used to build the transfer * * @return CommandInterface|callable */ abstract protected function createTransferAction(\SplFileInfo $file); /** * Hook to initialize subclasses * @codeCoverageIgnore */ protected function init() {} /** * Process and transfer a group of files * * @param array $files Files to transfer */ protected function transferFiles(array $files) { // Create the base event data object $event = array('sync' => $this, 'client' => $this->options['client']); $commands = array(); foreach ($files as $file) { if ($action = $this->createTransferAction($file)) { $event = array('command' => $action, 'file' => $file) + $event; $this->dispatch(self::BEFORE_TRANSFER, $event); if ($action instanceof CommandInterface) { $commands[] = $action; } elseif (is_callable($action)) { $action(); $this->dispatch(self::AFTER_TRANSFER, $event); } } } $this->transferCommands($commands); } /** * Transfer an array of commands in parallel * * @param array $commands Commands to transfer */ protected function transferCommands(array $commands) { if ($commands) { $this->options['client']->execute($commands); // Notify listeners that each command finished $event = array('sync' => $this, 'client' => $this->options['client']); foreach ($commands as $command) { $event['command'] = $command; $this->dispatch(self::AFTER_TRANSFER, $event); } } } } bucket = $bucket; return $this; } /** * Set the Amazon S3 client object that will send requests * * @param S3Client $client Amazon S3 client * * @return self */ public function setClient(S3Client $client) { $this->client = $client; return $this; } /** * Set a custom iterator that returns \SplFileInfo objects for the source data * * @param \Iterator $iterator * * @return self */ public function setSourceIterator(\Iterator $iterator) { $this->sourceIterator = $iterator; return $this; } /** * Set a custom object key provider instead of building one internally * * @param FileNameConverterInterface $converter Filename to object key provider * * @return self */ public function setSourceFilenameConverter(FilenameConverterInterface $converter) { $this->sourceConverter = $converter; return $this; } /** * Set a custom object key provider instead of building one internally * * @param FileNameConverterInterface $converter Filename to object key provider * * @return self */ public function setTargetFilenameConverter(FilenameConverterInterface $converter) { $this->targetConverter = $converter; return $this; } /** * Set the base directory of the files being transferred. The base directory is removed from each file path before * converting the file path to an object key or vice versa. * * @param string $baseDir Base directory, which will be deleted from each uploaded object key * * @return self */ public function setBaseDir($baseDir) { $this->baseDir = $baseDir; return $this; } /** * Specify a prefix to prepend to each Amazon S3 object key or the prefix where object are stored in a bucket * * Can be used to upload files to a pseudo sub-folder key or only download files from a pseudo sub-folder * * @param string $keyPrefix Prefix for each uploaded key * * @return self */ public function setKeyPrefix($keyPrefix) { // Removing leading slash $this->keyPrefix = ltrim($keyPrefix, '/'); return $this; } /** * Specify the delimiter used for the targeted filesystem (default delimiter is "/") * * @param string $delimiter Delimiter to use to separate paths * * @return self */ public function setDelimiter($delimiter) { $this->delimiter = $delimiter; return $this; } /** * Specify an array of operation parameters to apply to each operation executed by the sync object * * @param array $params Associative array of PutObject (upload) GetObject (download) parameters * * @return self */ public function setOperationParams(array $params) { $this->params = $params; return $this; } /** * Set the number of files that can be transferred concurrently * * @param int $concurrency Number of concurrent transfers * * @return self */ public function setConcurrency($concurrency) { $this->concurrency = $concurrency; return $this; } /** * Set to true to force transfers even if a file already exists and has not changed * * @param bool $force Set to true to force transfers without checking if it has changed * * @return self */ public function force($force = false) { $this->forcing = (bool) $force; return $this; } /** * Enable debug mode * * @param bool|resource $enabledOrResource Set to true or false to enable or disable debug output. Pass an opened * fopen resource to write to instead of writing to standard out. * @return self */ public function enableDebugOutput($enabledOrResource = true) { $this->debug = $enabledOrResource; return $this; } /** * Add a filename filter that uses a regular expression to filter out files that you do not wish to transfer. * * @param string $search Regular expression search (in preg_match format). Any filename that matches this regex * will not be transferred. * @return self */ public function addRegexFilter($search) { $this->assertFileIteratorSet(); $this->sourceIterator = new FilterIterator($this->sourceIterator, function ($i) use ($search) { return !preg_match($search, (string) $i); }); $this->sourceIterator->rewind(); return $this; } /** * Builds a UploadSync or DownloadSync object * * @return AbstractSync */ public function build() { $this->validateRequirements(); $this->sourceConverter = $this->sourceConverter ?: $this->getDefaultSourceConverter(); $this->targetConverter = $this->targetConverter ?: $this->getDefaultTargetConverter(); // Only wrap the source iterator in a changed files iterator if we are not forcing the transfers if (!$this->forcing) { $this->sourceIterator->rewind(); $this->sourceIterator = new ChangedFilesIterator( new \NoRewindIterator($this->sourceIterator), $this->getTargetIterator(), $this->sourceConverter, $this->targetConverter ); $this->sourceIterator->rewind(); } $sync = $this->specificBuild(); if ($this->params) { $this->addCustomParamListener($sync); } if ($this->debug) { $this->addDebugListener($sync, is_bool($this->debug) ? STDOUT : $this->debug); } return $sync; } /** * Hook to implement in subclasses * * @return self */ abstract protected function specificBuild(); /** * @return \Iterator */ abstract protected function getTargetIterator(); /** * @return FilenameConverterInterface */ abstract protected function getDefaultSourceConverter(); /** * @return FilenameConverterInterface */ abstract protected function getDefaultTargetConverter(); /** * Add a listener to the sync object to output debug information while transferring * * @param AbstractSync $sync Sync object to listen to * @param resource $resource Where to write debug messages */ abstract protected function addDebugListener(AbstractSync $sync, $resource); /** * Validate that the builder has the minimal requirements * * @throws RuntimeException if the builder is not configured completely */ protected function validateRequirements() { if (!$this->client) { throw new RuntimeException('No client was provided'); } if (!$this->bucket) { throw new RuntimeException('No bucket was provided'); } $this->assertFileIteratorSet(); } /** * Ensure that the base file iterator has been provided * * @throws RuntimeException */ protected function assertFileIteratorSet() { // Interesting... Need to use isset because: Object of class GlobIterator could not be converted to boolean if (!isset($this->sourceIterator)) { throw new RuntimeException('A source file iterator must be specified'); } } /** * Wraps a generated iterator in a filter iterator that removes directories * * @param \Iterator $iterator Iterator to wrap * * @return \Iterator * @throws UnexpectedValueException */ protected function filterIterator(\Iterator $iterator) { $f = new FilterIterator($iterator, function ($i) { if (!$i instanceof \SplFileInfo) { throw new UnexpectedValueException('All iterators for UploadSync must return SplFileInfo objects'); } return $i->isFile(); }); $f->rewind(); return $f; } /** * Add the custom param listener to a transfer object * * @param HasDispatcherInterface $sync */ protected function addCustomParamListener(HasDispatcherInterface $sync) { $params = $this->params; $sync->getEventDispatcher()->addListener( UploadSync::BEFORE_TRANSFER, function (Event $e) use ($params) { if ($e['command'] instanceof CommandInterface) { $e['command']->overwriteWith($params); } } ); } /** * Create an Amazon S3 file iterator based on the given builder settings * * @return OpendirIterator */ protected function createS3Iterator() { // Ensure that the stream wrapper is registered $this->client->registerStreamWrapper(); // Calculate the opendir() bucket and optional key prefix location $dir = "s3://{$this->bucket}"; if ($this->keyPrefix) { $dir .= '/' . ltrim($this->keyPrefix, '/ '); } // Use opendir so that we can pass stream context to the iterator $dh = opendir($dir, stream_context_create(array('s3' => array('delimiter' => '')))); // Add the trailing slash for the OpendirIterator concatenation if (!$this->keyPrefix) { $dir .= '/'; } return $this->filterIterator(new \NoRewindIterator(new OpendirIterator($dh, $dir))); } } targetIterator = $targetIterator; $this->sourceConverter = $sourceConverter; $this->targetConverter = $targetConverter; parent::__construct($sourceIterator); } public function accept() { $current = $this->current(); $key = $this->sourceConverter->convert((string) $current); if (!($data = $this->getTargetData($key))) { return true; } // Ensure the Content-Length matches and it hasn't been modified since the mtime return $current->getSize() != $data[0] || $current->getMTime() > $data[1]; } /** * Returns an array of the files from the target iterator that were not found in the source iterator * * @return array */ public function getUnmatched() { return array_keys($this->cache); } /** * Get key information from the target iterator for a particular filename * * @param string $key Target iterator filename * * @return array|bool Returns an array of data, or false if the key is not in the iterator */ protected function getTargetData($key) { if (isset($this->cache[$key])) { $result = $this->cache[$key]; unset($this->cache[$key]); return $result; } $it = $this->targetIterator; while ($it->valid()) { $value = $it->current(); $data = array($value->getSize(), $value->getMTime()); $filename = $this->targetConverter->convert((string) $value); if ($filename == $key) { return $data; } $this->cache[$filename] = $data; $it->next(); } return false; } } getPathname(); list($bucket, $key) = explode('/', substr($sourceFilename, 5), 2); $filename = $this->options['source_converter']->convert($sourceFilename); $this->createDirectory($filename); // Some S3 buckets contains nested files under the same name as a directory if (is_dir($filename)) { return false; } // Allow a previously interrupted download to resume if (file_exists($filename) && $this->options['resumable']) { return new ResumableDownload($this->options['client'], $bucket, $key, $filename); } return $this->options['client']->getCommand('GetObject', array( 'Bucket' => $bucket, 'Key' => $key, 'SaveAs' => $filename )); } /** * @codeCoverageIgnore */ protected function createDirectory($filename) { $directory = dirname($filename); // Some S3 clients create empty files to denote directories. Remove these so that we can create the directory. if (is_file($directory) && filesize($directory) == 0) { unlink($directory); } // Create the directory if it does not exist if (!is_dir($directory) && !mkdir($directory, 0777, true)) { $errors = error_get_last(); throw new RuntimeException('Could not create directory: ' . $directory . ' - ' . $errors['message']); } } protected function filterCommands(array $commands) { // Build a list of all of the directories in each command so that we don't attempt to create an empty dir in // the same parallel transfer as attempting to create a file in that dir $dirs = array(); foreach ($commands as $command) { $parts = array_values(array_filter(explode('/', $command['SaveAs']))); for ($i = 0, $total = count($parts); $i < $total; $i++) { $dir = ''; for ($j = 0; $j < $i; $j++) { $dir .= '/' . $parts[$j]; } if ($dir && !in_array($dir, $dirs)) { $dirs[] = $dir; } } } return array_filter($commands, function ($command) use ($dirs) { return !in_array($command['SaveAs'], $dirs); }); } protected function transferCommands(array $commands) { parent::transferCommands($this->filterCommands($commands)); } } directory = $directory; return $this; } /** * Call this function to allow partial downloads to be resumed if the download was previously interrupted * * @return self */ public function allowResumableDownloads() { $this->resumable = true; return $this; } protected function specificBuild() { $sync = new DownloadSync(array( 'client' => $this->client, 'bucket' => $this->bucket, 'iterator' => $this->sourceIterator, 'source_converter' => $this->sourceConverter, 'target_converter' => $this->targetConverter, 'concurrency' => $this->concurrency, 'resumable' => $this->resumable, 'directory' => $this->directory )); return $sync; } protected function getTargetIterator() { if (!$this->directory) { throw new RuntimeException('A directory is required'); } if (!is_dir($this->directory) && !mkdir($this->directory, 0777, true)) { // @codeCoverageIgnoreStart throw new RuntimeException('Unable to create root download directory: ' . $this->directory); // @codeCoverageIgnoreEnd } return $this->filterIterator( new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($this->directory)) ); } protected function getDefaultSourceConverter() { return new KeyConverter( "s3://{$this->bucket}/{$this->baseDir}", $this->directory . DIRECTORY_SEPARATOR, $this->delimiter ); } protected function getDefaultTargetConverter() { return new KeyConverter("s3://{$this->bucket}/{$this->baseDir}", '', $this->delimiter); } protected function assertFileIteratorSet() { $this->sourceIterator = $this->sourceIterator ?: $this->createS3Iterator(); } protected function addDebugListener(AbstractSync $sync, $resource) { $sync->getEventDispatcher()->addListener(UploadSync::BEFORE_TRANSFER, function (Event $e) use ($resource) { if ($e['command'] instanceof CommandInterface) { $from = $e['command']['Bucket'] . '/' . $e['command']['Key']; $to = $e['command']['SaveAs'] instanceof EntityBodyInterface ? $e['command']['SaveAs']->getUri() : $e['command']['SaveAs']; fwrite($resource, "Downloading {$from} -> {$to}\n"); } elseif ($e['command'] instanceof ResumableDownload) { $from = $e['command']->getBucket() . '/' . $e['command']->getKey(); $to = $e['command']->getFilename(); fwrite($resource, "Resuming {$from} -> {$to}\n"); } }); } } baseDir = (string) $baseDir; $this->prefix = $prefix; $this->delimiter = $delimiter; } public function convert($filename) { $key = $filename; // Remove base directory from the key (only the first occurrence) if ($this->baseDir && (false !== $pos = strpos($filename, $this->baseDir))) { $key = substr_replace($key, '', $pos, strlen($this->baseDir)); } // Replace Windows directory separators to become Unix style, and convert that to the custom dir separator $key = str_replace('/', $this->delimiter, str_replace('\\', '/', $key)); // Add the key prefix and remove double slashes that are not in the protocol (e.g. prefixed with ":") $delim = preg_quote($this->delimiter); $key = preg_replace( "#(?delimiter, $this->prefix . $key ); return $key; } } options['multipart_upload_size']) { $this->options['multipart_upload_size'] = AbstractTransfer::MIN_PART_SIZE; } } protected function createTransferAction(\SplFileInfo $file) { // Open the file for reading $filename = $file->getPathName(); if (!($resource = fopen($filename, 'r'))) { // @codeCoverageIgnoreStart throw new RuntimeException("Could not open {$filename} for reading"); // @codeCoverageIgnoreEnd } $key = $this->options['source_converter']->convert($filename); $body = EntityBody::factory($resource); // Determine how the ACL should be applied if ($acl = $this->options['acl']) { $aclType = is_string($this->options['acl']) ? 'ACL' : 'ACP'; } else { $acl = 'private'; $aclType = 'ACL'; } // Use a multi-part upload if the file is larger than the cutoff size and is a regular file if ($body->getWrapper() == 'plainfile' && $file->getSize() >= $this->options['multipart_upload_size']) { $builder = UploadBuilder::newInstance() ->setBucket($this->options['bucket']) ->setKey($key) ->setMinPartSize($this->options['multipart_upload_size']) ->setOption($aclType, $acl) ->setClient($this->options['client']) ->setSource($body) ->setConcurrency($this->options['concurrency']); $this->dispatch( self::BEFORE_MULTIPART_BUILD, array('builder' => $builder, 'file' => $file) ); return $builder->build(); } return $this->options['client']->getCommand('PutObject', array( 'Bucket' => $this->options['bucket'], 'Key' => $key, 'Body' => $body, $aclType => $acl )); } } baseDir = $path; $this->sourceIterator = $this->filterIterator(new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator( $path, FI::SKIP_DOTS | FI::UNIX_PATHS | FI::FOLLOW_SYMLINKS ))); return $this; } /** * Set a glob expression that will match files to upload to Amazon S3 * * @param string $glob Glob expression * * @return self * @link http://www.php.net/manual/en/function.glob.php */ public function uploadFromGlob($glob) { $this->sourceIterator = $this->filterIterator( new \GlobIterator($glob, FI::SKIP_DOTS | FI::UNIX_PATHS | FI::FOLLOW_SYMLINKS) ); return $this; } /** * Set a canned ACL to apply to each uploaded object * * @param string $acl Canned ACL for each upload * * @return self */ public function setAcl($acl) { $this->acp = $acl; return $this; } /** * Set an Access Control Policy to apply to each uploaded object * * @param Acp $acp Access control policy * * @return self */ public function setAcp(Acp $acp) { $this->acp = $acp; return $this; } /** * Set the multipart upload size threshold. When the size of a file exceeds this value, the file will be uploaded * using a multipart upload. * * @param int $size Size threshold * * @return self */ public function setMultipartUploadSize($size) { $this->multipartUploadSize = $size; return $this; } protected function specificBuild() { $sync = new UploadSync(array( 'client' => $this->client, 'bucket' => $this->bucket, 'iterator' => $this->sourceIterator, 'source_converter' => $this->sourceConverter, 'target_converter' => $this->targetConverter, 'concurrency' => $this->concurrency, 'multipart_upload_size' => $this->multipartUploadSize, 'acl' => $this->acp )); return $sync; } protected function addCustomParamListener(HasDispatcherInterface $sync) { // Handle the special multi-part upload event parent::addCustomParamListener($sync); $params = $this->params; $sync->getEventDispatcher()->addListener( UploadSync::BEFORE_MULTIPART_BUILD, function (Event $e) use ($params) { foreach ($params as $k => $v) { $e['builder']->setOption($k, $v); } } ); } protected function getTargetIterator() { return $this->createS3Iterator(); } protected function getDefaultSourceConverter() { return new KeyConverter($this->baseDir, $this->keyPrefix . $this->delimiter, $this->delimiter); } protected function getDefaultTargetConverter() { return new KeyConverter('s3://' . $this->bucket . '/', '', DIRECTORY_SEPARATOR); } protected function addDebugListener(AbstractSync $sync, $resource) { $sync->getEventDispatcher()->addListener(UploadSync::BEFORE_TRANSFER, function (Event $e) use ($resource) { $c = $e['command']; if ($c instanceof CommandInterface) { $uri = $c['Body']->getUri(); $size = $c['Body']->getSize(); fwrite($resource, "Uploading {$uri} -> {$c['Key']} ({$size} bytes)\n"); return; } // Multipart upload $body = $c->getSource(); $totalSize = $body->getSize(); $progress = 0; fwrite($resource, "Beginning multipart upload: " . $body->getUri() . ' -> '); fwrite($resource, $c->getState()->getFromId('Key') . " ({$totalSize} bytes)\n"); $c->getEventDispatcher()->addListener( AbstractTransfer::BEFORE_PART_UPLOAD, function ($e) use (&$progress, $totalSize, $resource) { $command = $e['command']; $size = $command['Body']->getContentLength(); $percentage = number_format(($progress / $totalSize) * 100, 2); fwrite($resource, "- Part {$command['PartNumber']} ({$size} bytes, {$percentage}%)\n"); $progress += $size; } ); }); } } '2010-12-01', 'endpointPrefix' => 'email', 'serviceFullName' => 'Amazon Simple Email Service', 'serviceAbbreviation' => 'Amazon SES', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Ses', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'email.us-east-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'email.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'email.eu-west-1.amazonaws.com', ), ), 'operations' => array( 'DeleteIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteIdentity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'DeleteVerifiedEmailAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'deprecated' => true, 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteVerifiedEmailAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EmailAddress' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetIdentityDkimAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetIdentityDkimAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetIdentityDkimAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identities' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Identities.member', 'items' => array( 'name' => 'Identity', 'type' => 'string', ), ), ), ), 'GetIdentityNotificationAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetIdentityNotificationAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetIdentityNotificationAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identities' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Identities.member', 'items' => array( 'name' => 'Identity', 'type' => 'string', ), ), ), ), 'GetIdentityVerificationAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetIdentityVerificationAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetIdentityVerificationAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identities' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Identities.member', 'items' => array( 'name' => 'Identity', 'type' => 'string', ), ), ), ), 'GetSendQuota' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSendQuotaResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSendQuota', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), ), 'GetSendStatistics' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSendStatisticsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSendStatistics', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), ), 'ListIdentities' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListIdentitiesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListIdentities', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'IdentityType' => array( 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MaxItems' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), ), 'ListVerifiedEmailAddresses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListVerifiedEmailAddressesResponse', 'responseType' => 'model', 'deprecated' => true, 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListVerifiedEmailAddresses', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), ), ), 'SendEmail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SendEmailResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SendEmail', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Source' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Destination' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'ToAddresses' => array( 'type' => 'array', 'sentAs' => 'ToAddresses.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), 'CcAddresses' => array( 'type' => 'array', 'sentAs' => 'CcAddresses.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), 'BccAddresses' => array( 'type' => 'array', 'sentAs' => 'BccAddresses.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), ), ), 'Message' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Subject' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Data' => array( 'required' => true, 'type' => 'string', ), 'Charset' => array( 'type' => 'string', ), ), ), 'Body' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'Text' => array( 'type' => 'object', 'properties' => array( 'Data' => array( 'required' => true, 'type' => 'string', ), 'Charset' => array( 'type' => 'string', ), ), ), 'Html' => array( 'type' => 'object', 'properties' => array( 'Data' => array( 'required' => true, 'type' => 'string', ), 'Charset' => array( 'type' => 'string', ), ), ), ), ), ), ), 'ReplyToAddresses' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ReplyToAddresses.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), 'ReturnPath' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the action failed, and the message could not be sent. Check the error stack for more information about what caused the error.', 'class' => 'MessageRejectedException', ), ), ), 'SendRawEmail' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SendRawEmailResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SendRawEmail', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Source' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Destinations' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Destinations.member', 'items' => array( 'name' => 'Address', 'type' => 'string', ), ), 'RawMessage' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Data' => array( 'required' => true, 'type' => 'string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the action failed, and the message could not be sent. Check the error stack for more information about what caused the error.', 'class' => 'MessageRejectedException', ), ), ), 'SetIdentityDkimEnabled' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetIdentityDkimEnabled', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DkimEnabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'SetIdentityFeedbackForwardingEnabled' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetIdentityFeedbackForwardingEnabled', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ForwardingEnabled' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), ), 'SetIdentityNotificationTopic' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetIdentityNotificationTopic', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Identity' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NotificationType' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'SnsTopic' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'VerifyDomainDkim' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'VerifyDomainDkimResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'VerifyDomainDkim', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Domain' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'VerifyDomainIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'VerifyDomainIdentityResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'VerifyDomainIdentity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'Domain' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'VerifyEmailAddress' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'deprecated' => true, 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'VerifyEmailAddress', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EmailAddress' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'VerifyEmailIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'VerifyEmailIdentity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-12-01', ), 'EmailAddress' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'GetIdentityDkimAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DkimAttributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'object', 'properties' => array( 'DkimEnabled' => array( 'type' => 'boolean', ), 'DkimVerificationStatus' => array( 'type' => 'string', ), 'DkimTokens' => array( 'type' => 'array', 'items' => array( 'name' => 'VerificationToken', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), ), ), 'additionalProperties' => false, ), ), ), 'GetIdentityNotificationAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'NotificationAttributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'object', 'properties' => array( 'BounceTopic' => array( 'type' => 'string', ), 'ComplaintTopic' => array( 'type' => 'string', ), 'ForwardingEnabled' => array( 'type' => 'boolean', ), ), ), ), ), 'additionalProperties' => false, ), ), ), 'GetIdentityVerificationAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VerificationAttributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'object', 'properties' => array( 'VerificationStatus' => array( 'type' => 'string', ), 'VerificationToken' => array( 'type' => 'string', ), ), ), ), ), 'additionalProperties' => false, ), ), ), 'GetSendQuotaResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Max24HourSend' => array( 'type' => 'numeric', 'location' => 'xml', ), 'MaxSendRate' => array( 'type' => 'numeric', 'location' => 'xml', ), 'SentLast24Hours' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'GetSendStatisticsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SendDataPoints' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'SendDataPoint', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'Timestamp' => array( 'type' => 'string', ), 'DeliveryAttempts' => array( 'type' => 'numeric', ), 'Bounces' => array( 'type' => 'numeric', ), 'Complaints' => array( 'type' => 'numeric', ), 'Rejects' => array( 'type' => 'numeric', ), ), ), ), ), ), 'ListIdentitiesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Identities' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Identity', 'type' => 'string', 'sentAs' => 'member', ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListVerifiedEmailAddressesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VerifiedEmailAddresses' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Address', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'SendEmailResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MessageId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'SendRawEmailResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MessageId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'VerifyDomainDkimResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DkimTokens' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'VerificationToken', 'type' => 'string', 'sentAs' => 'member', ), ), ), ), 'VerifyDomainIdentityResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VerificationToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'ListIdentities' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'limit_key' => 'MaxItems', 'result_key' => 'Identities', ), 'ListVerifiedEmailAddresses' => array( 'result_key' => 'VerifiedEmailAddresses', ), ), ), 'waiters' => array( '__default__' => array( 'interval' => 3, 'max_attempts' => 20, ), 'IdentityExists' => array( 'operation' => 'GetIdentityVerificationAttributes', 'success.type' => 'output', 'success.path' => 'VerificationAttributes/*/VerificationStatus', 'success.value' => true, ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/ses-%s.php', Options::SIGNATURE_SERVICE => 'ses', )) ->build(); } } '2009-04-15', 'endpointPrefix' => 'sdb', 'serviceFullName' => 'Amazon SimpleDB', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v2', 'namespace' => 'SimpleDb', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sdb.sa-east-1.amazonaws.com', ), ), 'operations' => array( 'BatchDeleteAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'BatchDeleteAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Items' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Item', 'items' => array( 'name' => 'Item', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'ItemName', ), 'Attributes' => array( 'type' => 'array', 'sentAs' => 'Attribute', 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'AlternateValueEncoding' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'BatchPutAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'BatchPutAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Items' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Item', 'items' => array( 'name' => 'Item', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', 'sentAs' => 'ItemName', ), 'Attributes' => array( 'required' => true, 'type' => 'array', 'sentAs' => 'Attribute', 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'Value' => array( 'required' => true, 'type' => 'string', ), 'Replace' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The item name was specified more than once.', 'class' => 'DuplicateItemNameException', ), array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), array( 'reason' => 'Too many attributes in this item.', 'class' => 'NumberItemAttributesExceededException', ), array( 'reason' => 'Too many attributes in this domain.', 'class' => 'NumberDomainAttributesExceededException', ), array( 'reason' => 'Too many bytes in this domain.', 'class' => 'NumberDomainBytesExceededException', ), array( 'reason' => 'Too many items exist in a single call.', 'class' => 'NumberSubmittedItemsExceededException', ), array( 'reason' => 'Too many attributes exist in a single call.', 'class' => 'NumberSubmittedAttributesExceededException', ), ), ), 'CreateDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateDomain', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'Too many domains exist per this account.', 'class' => 'NumberDomainsExceededException', ), ), ), 'DeleteAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ItemName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Attribute', 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'AlternateValueEncoding' => array( 'type' => 'string', ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), array( 'reason' => 'The specified attribute does not exist.', 'class' => 'AttributeDoesNotExistException', ), ), ), 'DeleteDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteDomain', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), ), ), 'DomainMetadata' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DomainMetadataResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DomainMetadata', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), ), ), 'GetAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetAttributesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ItemName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AttributeName', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), ), ), 'ListDomains' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListDomainsResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListDomains', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'MaxNumberOfDomains' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The specified NextToken is not valid.', 'class' => 'InvalidNextTokenException', ), ), ), 'PutAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'PutAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'DomainName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ItemName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'Attribute', 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'properties' => array( 'Name' => array( 'required' => true, 'type' => 'string', ), 'Value' => array( 'required' => true, 'type' => 'string', ), 'Replace' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'Expected' => array( 'type' => 'object', 'location' => 'aws.query', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'Exists' => array( 'type' => 'boolean', 'format' => 'boolean-string', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), array( 'reason' => 'Too many attributes in this domain.', 'class' => 'NumberDomainAttributesExceededException', ), array( 'reason' => 'Too many bytes in this domain.', 'class' => 'NumberDomainBytesExceededException', ), array( 'reason' => 'Too many attributes in this item.', 'class' => 'NumberItemAttributesExceededException', ), array( 'reason' => 'The specified attribute does not exist.', 'class' => 'AttributeDoesNotExistException', ), ), ), 'Select' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SelectResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'Select', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2009-04-15', ), 'SelectExpression' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), 'ConsistentRead' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The value for a parameter is invalid.', 'class' => 'InvalidParameterValueException', ), array( 'reason' => 'The specified NextToken is not valid.', 'class' => 'InvalidNextTokenException', ), array( 'reason' => 'Too many predicates exist in the query expression.', 'class' => 'InvalidNumberPredicatesException', ), array( 'reason' => 'Too many predicates exist in the query expression.', 'class' => 'InvalidNumberValueTestsException', ), array( 'reason' => 'The specified query expression syntax is not valid.', 'class' => 'InvalidQueryExpressionException', ), array( 'reason' => 'The request must contain the specified missing parameter.', 'class' => 'MissingParameterException', ), array( 'reason' => 'The specified domain does not exist.', 'class' => 'NoSuchDomainException', ), array( 'reason' => 'A timeout occurred when attempting to query the specified domain with specified query expression.', 'class' => 'RequestTimeoutException', ), array( 'reason' => 'Too many attributes requested.', 'class' => 'TooManyRequestedAttributesException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'DomainMetadataResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ItemCount' => array( 'type' => 'numeric', 'location' => 'xml', ), 'ItemNamesSizeBytes' => array( 'type' => 'numeric', 'location' => 'xml', ), 'AttributeNameCount' => array( 'type' => 'numeric', 'location' => 'xml', ), 'AttributeNamesSizeBytes' => array( 'type' => 'numeric', 'location' => 'xml', ), 'AttributeValueCount' => array( 'type' => 'numeric', 'location' => 'xml', ), 'AttributeValuesSizeBytes' => array( 'type' => 'numeric', 'location' => 'xml', ), 'Timestamp' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'GetAttributesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Attribute', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'sentAs' => 'Attribute', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'AlternateValueEncoding' => array( 'type' => 'string', ), ), ), ), ), ), 'ListDomainsResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DomainNames' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'DomainName', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'DomainName', 'type' => 'string', 'sentAs' => 'DomainName', ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'SelectResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Items' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Item', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'Item', 'type' => 'object', 'sentAs' => 'Item', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'array', 'sentAs' => 'Attribute', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'sentAs' => 'Attribute', 'properties' => array( 'Name' => array( 'type' => 'string', ), 'AlternateNameEncoding' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), 'AlternateValueEncoding' => array( 'type' => 'string', ), ), ), ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/simpledb-%s.php' )) ->setIteratorsConfig(array( 'token_key' => 'NextToken', 'token_param' => 'NextToken', 'operations' => array( 'ListDomains' => array( 'result_key' => 'DomainNames', 'limit_key' => 'MaxNumberOfDomains' ), 'Select' => array( 'result_key' => 'Items' ) ) )) ->build(); } } array( 'Message', 'MessageId', 'Timestamp', 'TopicArn', 'Type', 'Signature', 'SigningCertURL', ), 'SubscriptionConfirmation' => array( 'SubscribeURL', 'Token' ), 'UnsubscribeConfirmation' => array( 'SubscribeURL', 'Token' ), ); protected static $signableKeys = array( 'Message', 'MessageId', 'Subject', 'SubscribeURL', 'Timestamp', 'Token', 'TopicArn', 'Type', ); /** * @var Collection The message data */ protected $data; /** * Creates a Message object from an array of raw message data * * @param array $data The message data * * @return Message * @throws InvalidArgumentException If a valid type is not provided or there are other required keys missing */ public static function fromArray(array $data) { // Make sure the type key is set if (!isset($data['Type'])) { throw new InvalidArgumentException('The "Type" key must be provided to instantiate a Message object.'); } // Determine required keys and create a collection from the message data $requiredKeys = array_merge( self::$requiredKeys['__default'], isset(self::$requiredKeys[$data['Type']]) ? self::$requiredKeys[$data['Type']] : array() ); $data = Collection::fromConfig($data, array(), $requiredKeys); return new self($data); } /** * Creates a message object from the raw POST data * * @return Message * @throws UnexpectedValueException If the POST data is absent, or not a valid JSON document */ public static function fromRawPostData() { $data = json_decode(file_get_contents('php://input'), true); if (!is_array($data)) { throw new UnexpectedValueException('POST data absent, or not a valid JSON document', json_last_error()); } return self::fromArray($data); } /** * @param Collection $data A Collection of message data with all required keys */ public function __construct(Collection $data) { $this->data = $data; } /** * Get the entire message data as a Collection * * @return Collection */ public function getData() { return $this->data; } /** * Gets a single key from the message data * * @return string */ public function get($key) { return $this->data->get($key); } /** * Builds a newline delimited string to sign according to the specs * * @return string * @link http://docs.aws.amazon.com/sns/latest/gsg/SendMessageToHttp.verify.signature.html */ public function getStringToSign() { $stringToSign = ''; $data = $this->data->toArray(); ksort($data); foreach ($data as $key => $value) { if (in_array($key, self::$signableKeys)) { $stringToSign .= "{$key}\n{$value}\n"; } } return $stringToSign; } } client = $client ?: new Client(); } /** * Validates a message from SNS to ensure that it was delivered by AWS * * @param Message $message The message to validate * * @throws CannotGetPublicKeyFromCertificateException If the certificate cannot be retrieved * @throws CertificateFromUnrecognizedSourceException If the certificate's source cannot be verified * @throws InvalidMessageSignatureException If the message's signature is invalid */ public function validate(Message $message) { // Get the cert's URL and ensure it is from AWS $certUrl = Url::factory($message->get('SigningCertURL')); if ('.amazonaws.com' != substr($certUrl->getHost(), -14)) { throw new CertificateFromUnrecognizedSourceException(); } // Get the cert itself and extract the public key $certificate = $this->client->get((string) $certUrl)->send()->getBody(); $publicKey = openssl_get_publickey($certificate); if (!$publicKey) { throw new CannotGetPublicKeyFromCertificateException(); } // Verify the signature of the message $stringToSign = $message->getStringToSign(); $incomingSignature = base64_decode($message->get('Signature')); if (!openssl_verify($stringToSign, $incomingSignature, $publicKey, OPENSSL_ALGO_SHA1)) { throw new InvalidMessageSignatureException(); } } /** * Determines if a message is valid and that is was delivered by AWS. This method does not throw exceptions and * returns a simple boolean value. * * @param Message $message The message to validate * * @return bool */ public function isValid(Message $message) { try { $this->validate($message); return true; } catch (SnsMessageValidatorException $e) { return false; } } } '2010-03-31', 'endpointPrefix' => 'sns', 'serviceFullName' => 'Amazon Simple Notification Service', 'serviceAbbreviation' => 'Amazon SNS', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Sns', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sns.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AddPermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddPermission', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Label' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AWSAccountId' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AWSAccountId.member', 'items' => array( 'name' => 'delegate', 'type' => 'string', ), ), 'ActionName' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ActionName.member', 'items' => array( 'name' => 'action', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'ConfirmSubscription' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ConfirmSubscriptionResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ConfirmSubscription', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Token' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AuthenticateOnUnsubscribe' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the customer already owns the maximum allowed number of subscriptions.', 'class' => 'SubscriptionLimitExceededException', ), array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'CreatePlatformApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreatePlatformApplicationResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreatePlatformApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Platform' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attributes.entry', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'String', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'CreatePlatformEndpoint' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateEndpointResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreatePlatformEndpoint', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Token' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'CustomUserData' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attributes.entry', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'String', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'CreateTopic' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateTopicResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateTopic', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates that the customer already owns the maximum allowed number of topics.', 'class' => 'TopicLimitExceededException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'DeleteEndpoint' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteEndpoint', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'EndpointArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'DeletePlatformApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeletePlatformApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'DeleteTopic' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteTopic', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'GetEndpointAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetEndpointAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetEndpointAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'EndpointArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'GetPlatformApplicationAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetPlatformApplicationAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetPlatformApplicationAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'GetSubscriptionAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSubscriptionAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSubscriptionAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'SubscriptionArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'GetTopicAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetTopicAttributesResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetTopicAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'ListEndpointsByPlatformApplication' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListEndpointsByPlatformApplicationResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListEndpointsByPlatformApplication', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'ListPlatformApplications' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListPlatformApplicationsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListPlatformApplications', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'ListSubscriptions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListSubscriptionsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListSubscriptions', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'ListSubscriptionsByTopic' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListSubscriptionsByTopicResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListSubscriptionsByTopic', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'ListTopics' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListTopicsResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListTopics', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'NextToken' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'Publish' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'PublishResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'Publish', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'TargetArn' => array( 'type' => 'string', 'location' => 'aws.query', ), 'Message' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Subject' => array( 'type' => 'string', 'location' => 'aws.query', ), 'MessageStructure' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Exception error indicating endpoint disabled.', 'class' => 'EndpointDisabledException', ), array( 'reason' => 'Exception error indicating platform application disabled.', 'class' => 'PlatformApplicationDisabledException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'RemovePermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemovePermission', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Label' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'SetEndpointAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetEndpointAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'EndpointArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attributes.entry', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'String', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'SetPlatformApplicationAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetPlatformApplicationAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'PlatformApplicationArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attributes.entry', 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'String', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), 'SetSubscriptionAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetSubscriptionAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'SubscriptionArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeValue' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'SetTopicAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetTopicAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeValue' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'Subscribe' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SubscribeResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'Subscribe', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'TopicArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Protocol' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Endpoint' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that the customer already owns the maximum allowed number of subscriptions.', 'class' => 'SubscriptionLimitExceededException', ), array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), ), ), 'Unsubscribe' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'Unsubscribe', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2010-03-31', ), 'SubscriptionArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', 'class' => 'InvalidParameterException', ), array( 'reason' => 'Indicates an internal service error.', 'class' => 'InternalErrorException', ), array( 'reason' => 'Indicates that the user has been denied access to the requested resource.', 'class' => 'AuthorizationErrorException', ), array( 'reason' => 'Indicates that the requested resource does not exist.', 'class' => 'NotFoundException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ConfirmSubscriptionResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SubscriptionArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'CreatePlatformApplicationResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PlatformApplicationArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'CreateEndpointResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'EndpointArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'CreateTopicResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TopicArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetEndpointAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'GetPlatformApplicationAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'GetSubscriptionAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'GetTopicAttributesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'ListEndpointsByPlatformApplicationResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Endpoints' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Endpoint', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'EndpointArn' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListPlatformApplicationsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'PlatformApplications' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'PlatformApplication', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'PlatformApplicationArn' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'array', 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'entry', 'key', 'value', ), ), ), 'items' => array( 'name' => 'entry', 'type' => 'object', 'sentAs' => 'entry', 'additionalProperties' => true, 'properties' => array( 'key' => array( 'type' => 'string', ), 'value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListSubscriptionsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subscriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Subscription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SubscriptionArn' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), 'TopicArn' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListSubscriptionsByTopicResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Subscriptions' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Subscription', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'SubscriptionArn' => array( 'type' => 'string', ), 'Owner' => array( 'type' => 'string', ), 'Protocol' => array( 'type' => 'string', ), 'Endpoint' => array( 'type' => 'string', ), 'TopicArn' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListTopicsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Topics' => array( 'type' => 'array', 'location' => 'xml', 'items' => array( 'name' => 'Topic', 'type' => 'object', 'sentAs' => 'member', 'properties' => array( 'TopicArn' => array( 'type' => 'string', ), ), ), ), 'NextToken' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'PublishResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MessageId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'SubscribeResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SubscriptionArn' => array( 'type' => 'string', 'location' => 'xml', ), ), ), ), 'iterators' => array( 'operations' => array( 'ListEndpointsByPlatformApplication' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Endpoints', ), 'ListPlatformApplications' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'PlatformApplications', ), 'ListSubscriptions' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Subscriptions', ), 'ListSubscriptionsByTopic' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Subscriptions', ), 'ListTopics' => array( 'token_param' => 'NextToken', 'token_key' => 'NextToken', 'result_key' => 'Topics/*/TopicArn', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/sns-%s.php' )) ->build(); } } array('onCommandBeforeSend', -255)); } /** * Validates the MD5OfBody attribute against the body * * @param Event $event Event emitted * @throws SqsException when an MD5 mismatch occurs */ public function onCommandBeforeSend(Event $event) { if ($event['command']->getName() != 'ReceiveMessage') { return; } $result = $event['command']->getResult(); if (isset($result['Messages'])) { foreach ($result['Messages'] as $message) { if ($message['MD5OfBody'] != md5($message['Body'])) { throw new SqsException('Body MD5 mismatch for ' . var_export($message, true)); } } } } } array('onCommandBeforeSend', -255)); } /** * Updates the request URL to use the Queue URL * * @param Event $event Event emitted */ public function onCommandBeforeSend(Event $event) { /** @var $command AbstractCommand */ $command = $event['command']; if ($command->hasKey('QueueUrl')) { $request = $command->getRequest(); $requestUrl = $request->getUrl(true); $request->setUrl($requestUrl->combine($command->get('QueueUrl'))); $request->getParams()->remove('QueueUrl'); } } } '2012-11-05', 'endpointPrefix' => 'sqs', 'serviceFullName' => 'Amazon Simple Queue Service', 'serviceAbbreviation' => 'Amazon SQS', 'serviceType' => 'query', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Sqs', 'regions' => array( 'us-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => true, 'https' => true, 'hostname' => 'sqs.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AddPermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AddPermission', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Label' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AWSAccountIds' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AWSAccountId', 'items' => array( 'name' => 'AWSAccountId', 'type' => 'string', ), ), 'Actions' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ActionName', 'items' => array( 'name' => 'ActionName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The action that you requested would violate a limit. For example, ReceiveMessage returns this error if the maximum number of messages inflight has already been reached. AddPermission returns this error if the maximum number of permissions for the queue has already been reached.', 'class' => 'OverLimitException', ), ), ), 'ChangeMessageVisibility' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ChangeMessageVisibility', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReceiptHandle' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'VisibilityTimeout' => array( 'required' => true, 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The message referred to is not in flight.', 'class' => 'MessageNotInflightException', ), array( 'reason' => 'The receipt handle provided is not valid.', 'class' => 'ReceiptHandleIsInvalidException', ), ), ), 'ChangeMessageVisibilityBatch' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ChangeMessageVisibilityBatchResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ChangeMessageVisibilityBatch', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Entries' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'ChangeMessageVisibilityBatchRequestEntry', 'items' => array( 'name' => 'ChangeMessageVisibilityBatchRequestEntry', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'ReceiptHandle' => array( 'required' => true, 'type' => 'string', ), 'VisibilityTimeout' => array( 'type' => 'numeric', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Batch request contains more number of entries than permissible.', 'class' => 'TooManyEntriesInBatchRequestException', ), array( 'reason' => 'Batch request does not contain an entry.', 'class' => 'EmptyBatchRequestException', ), array( 'reason' => 'Two or more batch entries have the same Id in the request.', 'class' => 'BatchEntryIdsNotDistinctException', ), array( 'reason' => 'The Id of a batch entry in a batch request does not abide by the specification.', 'class' => 'InvalidBatchEntryIdException', ), ), ), 'CreateQueue' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'CreateQueueResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'CreateQueue', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attribute', 'data' => array( 'keyName' => 'Name', 'valueName' => 'Value', ), 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'QueueAttributeName', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'You must wait 60 seconds after deleting a queue before you can create another with the same name.', 'class' => 'QueueDeletedRecentlyException', ), array( 'reason' => 'A queue already exists with this name. Amazon SQS returns this error only if the request includes attributes whose values differ from those of the existing queue.', 'class' => 'QueueNameExistsException', ), ), ), 'DeleteMessage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteMessage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'ReceiptHandle' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The receipt handle is not valid for the current version.', 'class' => 'InvalidIdFormatException', ), array( 'reason' => 'The receipt handle provided is not valid.', 'class' => 'ReceiptHandleIsInvalidException', ), ), ), 'DeleteMessageBatch' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DeleteMessageBatchResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteMessageBatch', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Entries' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'DeleteMessageBatchRequestEntry', 'items' => array( 'name' => 'DeleteMessageBatchRequestEntry', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'ReceiptHandle' => array( 'required' => true, 'type' => 'string', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Batch request contains more number of entries than permissible.', 'class' => 'TooManyEntriesInBatchRequestException', ), array( 'reason' => 'Batch request does not contain an entry.', 'class' => 'EmptyBatchRequestException', ), array( 'reason' => 'Two or more batch entries have the same Id in the request.', 'class' => 'BatchEntryIdsNotDistinctException', ), array( 'reason' => 'The Id of a batch entry in a batch request does not abide by the specification.', 'class' => 'InvalidBatchEntryIdException', ), ), ), 'DeleteQueue' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DeleteQueue', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'GetQueueAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetQueueAttributesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetQueueAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AttributeName', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'The attribute referred to does not exist.', 'class' => 'InvalidAttributeNameException', ), ), ), 'GetQueueUrl' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetQueueUrlResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetQueueUrl', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'QueueOwnerAWSAccountId' => array( 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The queue referred to does not exist.', 'class' => 'QueueDoesNotExistException', ), ), ), 'ListDeadLetterSourceQueues' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListDeadLetterSourceQueuesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListDeadLetterSourceQueues', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The queue referred to does not exist.', 'class' => 'QueueDoesNotExistException', ), ), ), 'ListQueues' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ListQueuesResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ListQueues', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueNamePrefix' => array( 'type' => 'string', 'location' => 'aws.query', ), ), ), 'ReceiveMessage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'ReceiveMessageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'ReceiveMessage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'AttributeNames' => array( 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'AttributeName', 'items' => array( 'name' => 'AttributeName', 'type' => 'string', ), ), 'MaxNumberOfMessages' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'VisibilityTimeout' => array( 'type' => 'numeric', 'location' => 'aws.query', ), 'WaitTimeSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The action that you requested would violate a limit. For example, ReceiveMessage returns this error if the maximum number of messages inflight has already been reached. AddPermission returns this error if the maximum number of permissions for the queue has already been reached.', 'class' => 'OverLimitException', ), ), ), 'RemovePermission' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'RemovePermission', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Label' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), ), ), 'SendMessage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SendMessageResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SendMessage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'MessageBody' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'DelaySeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', ), ), 'errorResponses' => array( array( 'reason' => 'The message contains characters outside the allowed set.', 'class' => 'InvalidMessageContentsException', ), ), ), 'SendMessageBatch' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'SendMessageBatchResult', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SendMessageBatch', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Entries' => array( 'required' => true, 'type' => 'array', 'location' => 'aws.query', 'sentAs' => 'SendMessageBatchRequestEntry', 'items' => array( 'name' => 'SendMessageBatchRequestEntry', 'type' => 'object', 'properties' => array( 'Id' => array( 'required' => true, 'type' => 'string', ), 'MessageBody' => array( 'required' => true, 'type' => 'string', ), 'DelaySeconds' => array( 'type' => 'numeric', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Batch request contains more number of entries than permissible.', 'class' => 'TooManyEntriesInBatchRequestException', ), array( 'reason' => 'Batch request does not contain an entry.', 'class' => 'EmptyBatchRequestException', ), array( 'reason' => 'Two or more batch entries have the same Id in the request.', 'class' => 'BatchEntryIdsNotDistinctException', ), array( 'reason' => 'The length of all the messages put together is more than the limit.', 'class' => 'BatchRequestTooLongException', ), array( 'reason' => 'The Id of a batch entry in a batch request does not abide by the specification.', 'class' => 'InvalidBatchEntryIdException', ), ), ), 'SetQueueAttributes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'SetQueueAttributes', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2012-11-05', ), 'QueueUrl' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', ), 'Attributes' => array( 'required' => true, 'type' => 'object', 'location' => 'aws.query', 'sentAs' => 'Attribute', 'data' => array( 'keyName' => 'Name', 'valueName' => 'Value', ), 'additionalProperties' => array( 'type' => 'string', 'data' => array( 'shape_name' => 'QueueAttributeName', ), ), ), ), 'errorResponses' => array( array( 'reason' => 'The attribute referred to does not exist.', 'class' => 'InvalidAttributeNameException', ), ), ), ), 'models' => array( 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ChangeMessageVisibilityBatchResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Successful' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'ChangeMessageVisibilityBatchResultEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'ChangeMessageVisibilityBatchResultEntry', 'type' => 'object', 'sentAs' => 'ChangeMessageVisibilityBatchResultEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), ), ), ), 'Failed' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'BatchResultErrorEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'BatchResultErrorEntry', 'type' => 'object', 'sentAs' => 'BatchResultErrorEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'SenderFault' => array( 'type' => 'boolean', ), 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), 'CreateQueueResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'QueueUrl' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'DeleteMessageBatchResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Successful' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'DeleteMessageBatchResultEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'DeleteMessageBatchResultEntry', 'type' => 'object', 'sentAs' => 'DeleteMessageBatchResultEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), ), ), ), 'Failed' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'BatchResultErrorEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'BatchResultErrorEntry', 'type' => 'object', 'sentAs' => 'BatchResultErrorEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'SenderFault' => array( 'type' => 'boolean', ), 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), 'GetQueueAttributesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Attributes' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Attribute', 'data' => array( 'xmlFlattened' => true, 'xmlMap' => array( 'Policy', 'VisibilityTimeout', 'MaximumMessageSize', 'MessageRetentionPeriod', 'ApproximateNumberOfMessages', 'ApproximateNumberOfMessagesNotVisible', 'CreatedTimestamp', 'LastModifiedTimestamp', 'QueueArn', 'ApproximateNumberOfMessagesDelayed', 'DelaySeconds', 'ReceiveMessageWaitTimeSeconds', 'RedrivePolicy', ), ), 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'Attribute', 'Name', 'Value', ), ), ), 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'sentAs' => 'Attribute', 'additionalProperties' => true, 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), 'GetQueueUrlResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'QueueUrl' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'ListDeadLetterSourceQueuesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'queueUrls' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'QueueUrl', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'QueueUrl', 'type' => 'string', 'sentAs' => 'QueueUrl', ), ), ), ), 'ListQueuesResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'QueueUrls' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'QueueUrl', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'QueueUrl', 'type' => 'string', 'sentAs' => 'QueueUrl', ), ), ), ), 'ReceiveMessageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Messages' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'Message', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'Message', 'type' => 'object', 'sentAs' => 'Message', 'properties' => array( 'MessageId' => array( 'type' => 'string', ), 'ReceiptHandle' => array( 'type' => 'string', ), 'MD5OfBody' => array( 'type' => 'string', ), 'Body' => array( 'type' => 'string', ), 'Attributes' => array( 'type' => 'array', 'sentAs' => 'Attribute', 'data' => array( 'xmlFlattened' => true, 'xmlMap' => array( 'Policy', 'VisibilityTimeout', 'MaximumMessageSize', 'MessageRetentionPeriod', 'ApproximateNumberOfMessages', 'ApproximateNumberOfMessagesNotVisible', 'CreatedTimestamp', 'LastModifiedTimestamp', 'QueueArn', 'ApproximateNumberOfMessagesDelayed', 'DelaySeconds', 'ReceiveMessageWaitTimeSeconds', 'RedrivePolicy', ), ), 'filters' => array( array( 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', 'args' => array( '@value', 'Attribute', 'Name', 'Value', ), ), ), 'items' => array( 'name' => 'Attribute', 'type' => 'object', 'sentAs' => 'Attribute', 'additionalProperties' => true, 'properties' => array( 'Name' => array( 'type' => 'string', ), 'Value' => array( 'type' => 'string', ), ), ), 'additionalProperties' => false, ), ), ), ), ), ), 'SendMessageResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'MD5OfMessageBody' => array( 'type' => 'string', 'location' => 'xml', ), 'MessageId' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'SendMessageBatchResult' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Successful' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'SendMessageBatchResultEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'SendMessageBatchResultEntry', 'type' => 'object', 'sentAs' => 'SendMessageBatchResultEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'MessageId' => array( 'type' => 'string', ), 'MD5OfMessageBody' => array( 'type' => 'string', ), ), ), ), 'Failed' => array( 'type' => 'array', 'location' => 'xml', 'sentAs' => 'BatchResultErrorEntry', 'data' => array( 'xmlFlattened' => true, ), 'items' => array( 'name' => 'BatchResultErrorEntry', 'type' => 'object', 'sentAs' => 'BatchResultErrorEntry', 'properties' => array( 'Id' => array( 'type' => 'string', ), 'SenderFault' => array( 'type' => 'boolean', ), 'Code' => array( 'type' => 'string', ), 'Message' => array( 'type' => 'string', ), ), ), ), ), ), ), 'iterators' => array( 'operations' => array( 'ListDeadLetterSourceQueues' => array( 'result_key' => 'queueUrls', ), 'ListQueues' => array( 'result_key' => 'QueueUrls', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/sqs-%s.php' )) ->build(); $client->addSubscriber(new QueueUrlListener()); $client->addSubscriber(new Md5ValidatorListener()); return $client; } /** * Converts a queue URL into a queue ARN. * * @param string $queueUrl The queue URL to perform the action on. Retrieved when the queue is first created. * * @return string An ARN representation of the queue URL. */ public function getQueueArn($queueUrl) { return strtr($queueUrl, array( 'http://' => 'arn:aws:', 'https://' => 'arn:aws:', '.amazonaws.com' => '', '/' => ':', '.' => ':', )); } } '2013-06-30', 'endpointPrefix' => 'storagegateway', 'serviceFullName' => 'AWS Storage Gateway', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'StorageGateway_20130630.', 'signatureVersion' => 'v4', 'namespace' => 'StorageGateway', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'storagegateway.cn-north-1.amazonaws.com.cn', ), ), 'operations' => array( 'ActivateGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivateGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ActivateGateway', ), 'ActivationKey' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 50, ), 'GatewayName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 255, ), 'GatewayTimezone' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 10, ), 'GatewayRegion' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 25, ), 'GatewayType' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 20, ), 'TapeDriveType' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 50, ), 'MediumChangerType' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 50, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'AddCache' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddCacheOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.AddCache', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'DiskIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', 'minLength' => 1, 'maxLength' => 300, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'AddUploadBuffer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddUploadBufferOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.AddUploadBuffer', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'DiskIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', 'minLength' => 1, 'maxLength' => 300, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'AddWorkingStorage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddWorkingStorageOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.AddWorkingStorage', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'DiskIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', 'minLength' => 1, 'maxLength' => 300, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CancelArchival' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CancelArchivalOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CancelArchival', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CancelRetrieval' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CancelRetrievalOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CancelRetrieval', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateCachediSCSIVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateCachediSCSIVolumeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateCachediSCSIVolume', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'VolumeSizeInBytes' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'json', ), 'TargetName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 200, ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'ClientToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 5, 'maxLength' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateSnapshot' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateSnapshotOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateSnapshot', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'SnapshotDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateSnapshotFromVolumeRecoveryPoint' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateSnapshotFromVolumeRecoveryPointOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateSnapshotFromVolumeRecoveryPoint', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'SnapshotDescription' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateStorediSCSIVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateStorediSCSIVolumeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateStorediSCSIVolume', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'DiskId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 300, ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'json', ), 'PreserveExistingData' => array( 'required' => true, 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'TargetName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 200, ), 'NetworkInterfaceId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'CreateTapes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateTapesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.CreateTapes', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeSizeInBytes' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'minimum' => 107374182400, 'maximum' => 2748779069440, ), 'ClientToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 5, 'maxLength' => 100, ), 'NumTapesToCreate' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 10, ), 'TapeBarcodePrefix' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 4, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteBandwidthRateLimit' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteBandwidthRateLimitOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteBandwidthRateLimit', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'BandwidthType' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 25, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteChapCredentials' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteChapCredentialsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteChapCredentials', ), 'TargetARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 800, ), 'InitiatorName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteGateway', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteSnapshotSchedule' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteSnapshotScheduleOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteSnapshotSchedule', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteTape' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteTapeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteTape', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteTapeArchive' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteTapeArchiveOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteTapeArchive', ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DeleteVolume' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DeleteVolumeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DeleteVolume', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeBandwidthRateLimit' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeBandwidthRateLimitOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeBandwidthRateLimit', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeCache' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCacheOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeCache', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeCachediSCSIVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCachediSCSIVolumesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeCachediSCSIVolumes', ), 'VolumeARNs' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeChapCredentials' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeChapCredentialsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeChapCredentials', ), 'TargetARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 800, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeGatewayInformation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeGatewayInformationOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeGatewayInformation', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeMaintenanceStartTime' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeMaintenanceStartTimeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeMaintenanceStartTime', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeSnapshotSchedule' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeSnapshotScheduleOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeSnapshotSchedule', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeStorediSCSIVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeStorediSCSIVolumesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeStorediSCSIVolumes', ), 'VolumeARNs' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTapeArchives' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTapeArchivesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeTapeArchives', ), 'TapeARNs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTapeRecoveryPoints' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTapeRecoveryPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeTapeRecoveryPoints', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTapes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTapesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeTapes', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'TapeARNs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeUploadBuffer' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeUploadBufferOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeUploadBuffer', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeVTLDevices' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeVTLDevicesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeVTLDevices', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'VTLDeviceARNs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VTLDeviceARN', 'type' => 'string', 'minLength' => 50, 'maxLength' => 500, ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeWorkingStorage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeWorkingStorageOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DescribeWorkingStorage', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'DisableGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DisableGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.DisableGateway', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ListGateways' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListGatewaysOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ListGateways', ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ListLocalDisks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListLocalDisksOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ListLocalDisks', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ListVolumeRecoveryPoints' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListVolumeRecoveryPointsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ListVolumeRecoveryPoints', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ListVolumes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ListVolumesOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ListVolumes', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'Marker' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1000, ), 'Limit' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'RetrieveTapeArchive' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RetrieveTapeArchiveOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.RetrieveTapeArchive', ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'RetrieveTapeRecoveryPoint' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RetrieveTapeRecoveryPointOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.RetrieveTapeRecoveryPoint', ), 'TapeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'ShutdownGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ShutdownGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.ShutdownGateway', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'StartGateway' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'StartGatewayOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.StartGateway', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateBandwidthRateLimit' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateBandwidthRateLimitOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateBandwidthRateLimit', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'AverageUploadRateLimitInBitsPerSec' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 51200, ), 'AverageDownloadRateLimitInBitsPerSec' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 102400, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateChapCredentials' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateChapCredentialsOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateChapCredentials', ), 'TargetARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 800, ), 'SecretToAuthenticateInitiator' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 12, 'maxLength' => 16, ), 'InitiatorName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), 'SecretToAuthenticateTarget' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 12, 'maxLength' => 16, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateGatewayInformation' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateGatewayInformationOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateGatewayInformation', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'GatewayName' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 2, 'maxLength' => 255, ), 'GatewayTimezone' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 3, 'maxLength' => 10, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateGatewaySoftwareNow' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateGatewaySoftwareNowOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateGatewaySoftwareNow', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateMaintenanceStartTime' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateMaintenanceStartTimeOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateMaintenanceStartTime', ), 'GatewayARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'HourOfDay' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'maximum' => 23, ), 'MinuteOfHour' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'maximum' => 59, ), 'DayOfWeek' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'maximum' => 6, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), 'UpdateSnapshotSchedule' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'UpdateSnapshotScheduleOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'StorageGateway_20130630.UpdateSnapshotSchedule', ), 'VolumeARN' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 50, 'maxLength' => 500, ), 'StartAt' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'maximum' => 23, ), 'RecurrenceInHours' => array( 'required' => true, 'type' => 'numeric', 'location' => 'json', 'minimum' => 1, 'maximum' => 24, ), 'Description' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 255, ), ), 'errorResponses' => array( array( 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', 'class' => 'InvalidGatewayRequestException', ), array( 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', 'class' => 'InternalServerErrorException', ), ), ), ), 'models' => array( 'ActivateGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'AddCacheOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'AddUploadBufferOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'AddWorkingStorageOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CancelArchivalOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CancelRetrievalOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateCachediSCSIVolumeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'TargetARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateSnapshotOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'SnapshotId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateSnapshotFromVolumeRecoveryPointOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'SnapshotId' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeRecoveryPointTime' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateStorediSCSIVolumeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeSizeInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'TargetARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'CreateTapesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARNs' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeARN', 'type' => 'string', ), ), ), ), 'DeleteBandwidthRateLimitOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteChapCredentialsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TargetARN' => array( 'type' => 'string', 'location' => 'json', ), 'InitiatorName' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteSnapshotScheduleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteTapeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteTapeArchiveOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DeleteVolumeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeBandwidthRateLimitOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'AverageUploadRateLimitInBitsPerSec' => array( 'type' => 'numeric', 'location' => 'json', ), 'AverageDownloadRateLimitInBitsPerSec' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DescribeCacheOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'DiskIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', ), ), 'CacheAllocatedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'CacheUsedPercentage' => array( 'type' => 'numeric', 'location' => 'json', ), 'CacheDirtyPercentage' => array( 'type' => 'numeric', 'location' => 'json', ), 'CacheHitPercentage' => array( 'type' => 'numeric', 'location' => 'json', ), 'CacheMissPercentage' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DescribeCachediSCSIVolumesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'CachediSCSIVolumes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'CachediSCSIVolume', 'type' => 'object', 'properties' => array( 'VolumeARN' => array( 'type' => 'string', ), 'VolumeId' => array( 'type' => 'string', ), 'VolumeType' => array( 'type' => 'string', ), 'VolumeStatus' => array( 'type' => 'string', ), 'VolumeSizeInBytes' => array( 'type' => 'numeric', ), 'VolumeProgress' => array( 'type' => 'numeric', ), 'SourceSnapshotId' => array( 'type' => 'string', ), 'VolumeiSCSIAttributes' => array( 'type' => 'object', 'properties' => array( 'TargetARN' => array( 'type' => 'string', ), 'NetworkInterfaceId' => array( 'type' => 'string', ), 'NetworkInterfacePort' => array( 'type' => 'numeric', ), 'LunNumber' => array( 'type' => 'numeric', ), 'ChapEnabled' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'DescribeChapCredentialsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'ChapCredentials' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ChapInfo', 'type' => 'object', 'properties' => array( 'TargetARN' => array( 'type' => 'string', ), 'SecretToAuthenticateInitiator' => array( 'type' => 'string', ), 'InitiatorName' => array( 'type' => 'string', ), 'SecretToAuthenticateTarget' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeGatewayInformationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'GatewayId' => array( 'type' => 'string', 'location' => 'json', ), 'GatewayTimezone' => array( 'type' => 'string', 'location' => 'json', ), 'GatewayState' => array( 'type' => 'string', 'location' => 'json', ), 'GatewayNetworkInterfaces' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'NetworkInterface', 'type' => 'object', 'properties' => array( 'Ipv4Address' => array( 'type' => 'string', ), 'MacAddress' => array( 'type' => 'string', ), 'Ipv6Address' => array( 'type' => 'string', ), ), ), ), 'GatewayType' => array( 'type' => 'string', 'location' => 'json', ), 'NextUpdateAvailabilityDate' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeMaintenanceStartTimeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'HourOfDay' => array( 'type' => 'numeric', 'location' => 'json', ), 'MinuteOfHour' => array( 'type' => 'numeric', 'location' => 'json', ), 'DayOfWeek' => array( 'type' => 'numeric', 'location' => 'json', ), 'Timezone' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeSnapshotScheduleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), 'StartAt' => array( 'type' => 'numeric', 'location' => 'json', ), 'RecurrenceInHours' => array( 'type' => 'numeric', 'location' => 'json', ), 'Description' => array( 'type' => 'string', 'location' => 'json', ), 'Timezone' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeStorediSCSIVolumesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'StorediSCSIVolumes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'StorediSCSIVolume', 'type' => 'object', 'properties' => array( 'VolumeARN' => array( 'type' => 'string', ), 'VolumeId' => array( 'type' => 'string', ), 'VolumeType' => array( 'type' => 'string', ), 'VolumeStatus' => array( 'type' => 'string', ), 'VolumeSizeInBytes' => array( 'type' => 'numeric', ), 'VolumeProgress' => array( 'type' => 'numeric', ), 'VolumeDiskId' => array( 'type' => 'string', ), 'SourceSnapshotId' => array( 'type' => 'string', ), 'PreservedExistingData' => array( 'type' => 'boolean', ), 'VolumeiSCSIAttributes' => array( 'type' => 'object', 'properties' => array( 'TargetARN' => array( 'type' => 'string', ), 'NetworkInterfaceId' => array( 'type' => 'string', ), 'NetworkInterfacePort' => array( 'type' => 'numeric', ), 'LunNumber' => array( 'type' => 'numeric', ), 'ChapEnabled' => array( 'type' => 'boolean', ), ), ), ), ), ), ), ), 'DescribeTapeArchivesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeArchives' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeArchive', 'type' => 'object', 'properties' => array( 'TapeARN' => array( 'type' => 'string', ), 'TapeBarcode' => array( 'type' => 'string', ), 'TapeSizeInBytes' => array( 'type' => 'numeric', ), 'CompletionTime' => array( 'type' => 'string', ), 'RetrievedTo' => array( 'type' => 'string', ), 'TapeStatus' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeTapeRecoveryPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'TapeRecoveryPointInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TapeRecoveryPointInfo', 'type' => 'object', 'properties' => array( 'TapeARN' => array( 'type' => 'string', ), 'TapeRecoveryPointTime' => array( 'type' => 'string', ), 'TapeSizeInBytes' => array( 'type' => 'numeric', ), 'TapeStatus' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeTapesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Tapes' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Tape', 'type' => 'object', 'properties' => array( 'TapeARN' => array( 'type' => 'string', ), 'TapeBarcode' => array( 'type' => 'string', ), 'TapeSizeInBytes' => array( 'type' => 'numeric', ), 'TapeStatus' => array( 'type' => 'string', ), 'VTLDevice' => array( 'type' => 'string', ), 'Progress' => array( 'type' => 'numeric', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeUploadBufferOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'DiskIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', ), ), 'UploadBufferUsedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'UploadBufferAllocatedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DescribeVTLDevicesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'VTLDevices' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VTLDevice', 'type' => 'object', 'properties' => array( 'VTLDeviceARN' => array( 'type' => 'string', ), 'VTLDeviceType' => array( 'type' => 'string', ), 'VTLDeviceVendor' => array( 'type' => 'string', ), 'VTLDeviceProductIdentifier' => array( 'type' => 'string', ), 'DeviceiSCSIAttributes' => array( 'type' => 'object', 'properties' => array( 'TargetARN' => array( 'type' => 'string', ), 'NetworkInterfaceId' => array( 'type' => 'string', ), 'NetworkInterfacePort' => array( 'type' => 'numeric', ), 'ChapEnabled' => array( 'type' => 'boolean', ), ), ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeWorkingStorageOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'DiskIds' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DiskId', 'type' => 'string', ), ), 'WorkingStorageUsedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), 'WorkingStorageAllocatedInBytes' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'DisableGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListGatewaysOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Gateways' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'GatewayInfo', 'type' => 'object', 'properties' => array( 'GatewayARN' => array( 'type' => 'string', ), 'GatewayType' => array( 'type' => 'string', ), 'GatewayOperationalState' => array( 'type' => 'string', ), ), ), ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ListLocalDisksOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'Disks' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Disk', 'type' => 'object', 'properties' => array( 'DiskId' => array( 'type' => 'string', ), 'DiskPath' => array( 'type' => 'string', ), 'DiskNode' => array( 'type' => 'string', ), 'DiskSizeInBytes' => array( 'type' => 'numeric', ), 'DiskAllocationType' => array( 'type' => 'string', ), 'DiskAllocationResource' => array( 'type' => 'string', ), ), ), ), ), ), 'ListVolumeRecoveryPointsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeRecoveryPointInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeRecoveryPointInfo', 'type' => 'object', 'properties' => array( 'VolumeARN' => array( 'type' => 'string', ), 'VolumeSizeInBytes' => array( 'type' => 'numeric', ), 'VolumeUsageInBytes' => array( 'type' => 'numeric', ), 'VolumeRecoveryPointTime' => array( 'type' => 'string', ), ), ), ), ), ), 'ListVolumesOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), 'Marker' => array( 'type' => 'string', 'location' => 'json', ), 'VolumeInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'VolumeInfo', 'type' => 'object', 'properties' => array( 'VolumeARN' => array( 'type' => 'string', ), 'VolumeType' => array( 'type' => 'string', ), ), ), ), ), ), 'RetrieveTapeArchiveOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'RetrieveTapeRecoveryPointOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TapeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ShutdownGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'StartGatewayOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateBandwidthRateLimitOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateChapCredentialsOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'TargetARN' => array( 'type' => 'string', 'location' => 'json', ), 'InitiatorName' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateGatewayInformationOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateGatewaySoftwareNowOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateMaintenanceStartTimeOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'GatewayARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'UpdateSnapshotScheduleOutput' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'VolumeARN' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeCachediSCSIVolumes' => array( 'result_key' => 'CachediSCSIVolumes', ), 'DescribeStorediSCSIVolumes' => array( 'result_key' => 'StorediSCSIVolumes', ), 'DescribeTapeArchives' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'TapeArchives', ), 'DescribeTapeRecoveryPoints' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'TapeRecoveryPointInfos', ), 'DescribeTapes' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'Tapes', ), 'DescribeVTLDevices' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'VTLDevices', ), 'ListGateways' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'Gateways', ), 'ListLocalDisks' => array( 'result_key' => 'Disks', ), 'ListVolumeRecoveryPoints' => array( 'result_key' => 'VolumeRecoveryPointInfos', ), 'ListVolumes' => array( 'token_param' => 'Marker', 'token_key' => 'Marker', 'limit_key' => 'Limit', 'result_key' => 'VolumeInfos', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/storagegateway-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } '2011-06-15', 'endpointPrefix' => 'sts', 'serviceFullName' => 'AWS Security Token Service', 'serviceAbbreviation' => 'AWS STS', 'serviceType' => 'query', 'globalEndpoint' => 'sts.amazonaws.com', 'resultWrapped' => true, 'signatureVersion' => 'v4', 'namespace' => 'Sts', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'sts.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'AssumeRole' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssumeRoleResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssumeRole', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'RoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), 'RoleSessionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 2, 'maxLength' => 32, ), 'Policy' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2048, ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 3600, ), 'ExternalId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 2, 'maxLength' => 96, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because the policy document was too large. The error message describes how big the policy document is, in packed form, as a percentage of what the API allows.', 'class' => 'PackedPolicyTooLargeException', ), ), ), 'AssumeRoleWithSAML' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssumeRoleWithSAMLResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssumeRoleWithSAML', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'RoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), 'PrincipalArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), 'SAMLAssertion' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 50000, ), 'Policy' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2048, ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 129600, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because the policy document was too large. The error message describes how big the policy document is, in packed form, as a percentage of what the API allows.', 'class' => 'PackedPolicyTooLargeException', ), array( 'reason' => 'The identity provider (IdP) reported that authentication failed. This might be because the claim is invalid. If this error is returned for the AssumeRoleWithWebIdentity operation, it can also mean that the claim has expired or has been explicitly revoked.', 'class' => 'IDPRejectedClaimException', ), array( 'reason' => 'The web identity token that was passed could not be validated by AWS. Get a new identity token from the identity provider and then retry the request.', 'class' => 'InvalidIdentityTokenException', ), array( 'reason' => 'The web identity token that was passed is expired or is not valid. Get a new identity token from the identity provider and then retry the request.', 'class' => 'ExpiredTokenException', ), ), ), 'AssumeRoleWithWebIdentity' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'AssumeRoleWithWebIdentityResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'AssumeRoleWithWebIdentity', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'RoleArn' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 20, 'maxLength' => 2048, ), 'RoleSessionName' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 2, 'maxLength' => 32, ), 'WebIdentityToken' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 2048, ), 'ProviderId' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 4, 'maxLength' => 2048, ), 'Policy' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2048, ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 129600, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because the policy document was too large. The error message describes how big the policy document is, in packed form, as a percentage of what the API allows.', 'class' => 'PackedPolicyTooLargeException', ), array( 'reason' => 'The identity provider (IdP) reported that authentication failed. This might be because the claim is invalid. If this error is returned for the AssumeRoleWithWebIdentity operation, it can also mean that the claim has expired or has been explicitly revoked.', 'class' => 'IDPRejectedClaimException', ), array( 'reason' => 'The request could not be fulfilled because the non-AWS identity provider (IDP) that was asked to verify the incoming identity token could not be reached. This is often a transient error caused by network conditions. Retry the request a limited number of times so that you don\'t exceed the request rate. If the error persists, the non-AWS identity provider might be down or not responding.', 'class' => 'IDPCommunicationErrorException', ), array( 'reason' => 'The web identity token that was passed could not be validated by AWS. Get a new identity token from the identity provider and then retry the request.', 'class' => 'InvalidIdentityTokenException', ), array( 'reason' => 'The web identity token that was passed is expired or is not valid. Get a new identity token from the identity provider and then retry the request.', 'class' => 'ExpiredTokenException', ), ), ), 'DecodeAuthorizationMessage' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'DecodeAuthorizationMessageResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'DecodeAuthorizationMessage', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'EncodedMessage' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 10240, ), ), 'errorResponses' => array( array( 'reason' => 'The error returned if the message passed to DecodeAuthorizationMessage was invalid. This can happen if the token contains invalid characters, such as linebreaks.', 'class' => 'InvalidAuthorizationMessageException', ), ), ), 'GetFederationToken' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetFederationTokenResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetFederationToken', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'Name' => array( 'required' => true, 'type' => 'string', 'location' => 'aws.query', 'minLength' => 2, 'maxLength' => 32, ), 'Policy' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 1, 'maxLength' => 2048, ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 129600, ), ), 'errorResponses' => array( array( 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', 'class' => 'MalformedPolicyDocumentException', ), array( 'reason' => 'The request was rejected because the policy document was too large. The error message describes how big the policy document is, in packed form, as a percentage of what the API allows.', 'class' => 'PackedPolicyTooLargeException', ), ), ), 'GetSessionToken' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\QueryCommand', 'responseClass' => 'GetSessionTokenResponse', 'responseType' => 'model', 'parameters' => array( 'Action' => array( 'static' => true, 'location' => 'aws.query', 'default' => 'GetSessionToken', ), 'Version' => array( 'static' => true, 'location' => 'aws.query', 'default' => '2011-06-15', ), 'DurationSeconds' => array( 'type' => 'numeric', 'location' => 'aws.query', 'minimum' => 900, 'maximum' => 129600, ), 'SerialNumber' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 9, 'maxLength' => 256, ), 'TokenCode' => array( 'type' => 'string', 'location' => 'aws.query', 'minLength' => 6, 'maxLength' => 6, ), ), ), ), 'models' => array( 'AssumeRoleResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), 'AssumedRoleUser' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AssumedRoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), ), ), 'PackedPolicySize' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'AssumeRoleWithSAMLResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), 'AssumedRoleUser' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AssumedRoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), ), ), 'PackedPolicySize' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'AssumeRoleWithWebIdentityResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), 'SubjectFromWebIdentityToken' => array( 'type' => 'string', 'location' => 'xml', ), 'AssumedRoleUser' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AssumedRoleId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), ), ), 'PackedPolicySize' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'DecodeAuthorizationMessageResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'DecodedMessage' => array( 'type' => 'string', 'location' => 'xml', ), ), ), 'GetFederationTokenResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), 'FederatedUser' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'FederatedUserId' => array( 'type' => 'string', ), 'Arn' => array( 'type' => 'string', ), ), ), 'PackedPolicySize' => array( 'type' => 'numeric', 'location' => 'xml', ), ), ), 'GetSessionTokenResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'Credentials' => array( 'type' => 'object', 'location' => 'xml', 'properties' => array( 'AccessKeyId' => array( 'type' => 'string', ), 'SecretAccessKey' => array( 'type' => 'string', ), 'SessionToken' => array( 'type' => 'string', ), 'Expiration' => array( 'type' => 'string', ), ), ), ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/sts-%s.php' )) ->build(); // Attach a listener to prevent AssumeRoleWithWebIdentity requests from being signed $client->getEventDispatcher()->addListener('command.before_send', function(Event $event) { /** @var AbstractCommand $command */ $command = $event['command']; if ($command->getName() === 'AssumeRoleWithWebIdentity') { /** @var EventDispatcher $dispatcher */ $dispatcher = $command->getRequest()->getEventDispatcher(); foreach ($dispatcher->getListeners('request.before_send') as $listener) { if (is_array($listener) && $listener[0] instanceof SignatureListener) { $dispatcher->removeListener('request.before_send', $listener); break; } } } }); return $client; } /** * Creates a credentials object from the credential data return by an STS operation * * @param Model $result The result of an STS operation * * @return Credentials * @throws InvalidArgumentException if the result does not contain credential data */ public function createCredentials(Model $result) { if (!$result->hasKey('Credentials')) { throw new InvalidArgumentException('The modeled result provided contained no credentials.'); } return new Credentials( $result->getPath('Credentials/AccessKeyId'), $result->getPath('Credentials/SecretAccessKey'), $result->getPath('Credentials/SessionToken'), $result->getPath('Credentials/Expiration') ); } } '2013-04-15', 'endpointPrefix' => 'support', 'serviceFullName' => 'AWS Support', 'serviceType' => 'json', 'jsonVersion' => '1.1', 'targetPrefix' => 'AWSSupport_20130415.', 'signatureVersion' => 'v4', 'namespace' => 'Support', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'support.us-east-1.amazonaws.com', ), ), 'operations' => array( 'AddCommunicationToCase' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'AddCommunicationToCaseResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.AddCommunicationToCase', ), 'caseId' => array( 'type' => 'string', 'location' => 'json', ), 'communicationBody' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 8000, ), 'ccEmailAddresses' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 10, 'items' => array( 'name' => 'CcEmailAddress', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when the CaseId requested could not be located.', 'class' => 'CaseIdNotFoundException', ), ), ), 'CreateCase' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'CreateCaseResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.CreateCase', ), 'subject' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'serviceCode' => array( 'type' => 'string', 'location' => 'json', ), 'severityCode' => array( 'type' => 'string', 'location' => 'json', ), 'categoryCode' => array( 'type' => 'string', 'location' => 'json', ), 'communicationBody' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 8000, ), 'ccEmailAddresses' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 10, 'items' => array( 'name' => 'CcEmailAddress', 'type' => 'string', ), ), 'language' => array( 'type' => 'string', 'location' => 'json', ), 'issueType' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when you have exceeded the case creation limit for an account.', 'class' => 'CaseCreationLimitExceededException', ), ), ), 'DescribeCases' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCasesResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeCases', ), 'caseIdList' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 100, 'items' => array( 'name' => 'CaseId', 'type' => 'string', ), ), 'displayId' => array( 'type' => 'string', 'location' => 'json', ), 'afterTime' => array( 'type' => 'string', 'location' => 'json', ), 'beforeTime' => array( 'type' => 'string', 'location' => 'json', ), 'includeResolvedCases' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'nextToken' => array( 'type' => 'string', 'location' => 'json', ), 'maxResults' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 10, 'maximum' => 100, ), 'language' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when the CaseId requested could not be located.', 'class' => 'CaseIdNotFoundException', ), ), ), 'DescribeCommunications' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeCommunicationsResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeCommunications', ), 'caseId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'beforeTime' => array( 'type' => 'string', 'location' => 'json', ), 'afterTime' => array( 'type' => 'string', 'location' => 'json', ), 'nextToken' => array( 'type' => 'string', 'location' => 'json', ), 'maxResults' => array( 'type' => 'numeric', 'location' => 'json', 'minimum' => 10, 'maximum' => 100, ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when the CaseId requested could not be located.', 'class' => 'CaseIdNotFoundException', ), ), ), 'DescribeServices' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeServicesResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeServices', ), 'serviceCodeList' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 100, 'items' => array( 'name' => 'ServiceCode', 'type' => 'string', ), ), 'language' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeSeverityLevels' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeSeverityLevelsResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeSeverityLevels', ), 'language' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTrustedAdvisorCheckRefreshStatuses' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrustedAdvisorCheckRefreshStatusesResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeTrustedAdvisorCheckRefreshStatuses', ), 'checkIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTrustedAdvisorCheckResult' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrustedAdvisorCheckResultResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeTrustedAdvisorCheckResult', ), 'checkId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), 'language' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTrustedAdvisorCheckSummaries' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrustedAdvisorCheckSummariesResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeTrustedAdvisorCheckSummaries', ), 'checkIds' => array( 'required' => true, 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'DescribeTrustedAdvisorChecks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DescribeTrustedAdvisorChecksResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.DescribeTrustedAdvisorChecks', ), 'language' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'RefreshTrustedAdvisorCheck' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'RefreshTrustedAdvisorCheckResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.RefreshTrustedAdvisorCheck', ), 'checkId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), ), ), 'ResolveCase' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ResolveCaseResponse', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.1', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'AWSSupport_20130415.ResolveCase', ), 'caseId' => array( 'type' => 'string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returns HTTP error 500.', 'class' => 'InternalServerErrorException', ), array( 'reason' => 'Returned when the CaseId requested could not be located.', 'class' => 'CaseIdNotFoundException', ), ), ), ), 'models' => array( 'AddCommunicationToCaseResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'result' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'CreateCaseResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'caseId' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeCasesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'cases' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'CaseDetails', 'type' => 'object', 'properties' => array( 'caseId' => array( 'type' => 'string', ), 'displayId' => array( 'type' => 'string', ), 'subject' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'serviceCode' => array( 'type' => 'string', ), 'categoryCode' => array( 'type' => 'string', ), 'severityCode' => array( 'type' => 'string', ), 'submittedBy' => array( 'type' => 'string', ), 'timeCreated' => array( 'type' => 'string', ), 'recentCommunications' => array( 'type' => 'object', 'properties' => array( 'communications' => array( 'type' => 'array', 'items' => array( 'name' => 'Communication', 'type' => 'object', 'properties' => array( 'caseId' => array( 'type' => 'string', ), 'body' => array( 'type' => 'string', ), 'submittedBy' => array( 'type' => 'string', ), 'timeCreated' => array( 'type' => 'string', ), ), ), ), 'nextToken' => array( 'type' => 'string', ), ), ), 'ccEmailAddresses' => array( 'type' => 'array', 'items' => array( 'name' => 'CcEmailAddress', 'type' => 'string', ), ), 'language' => array( 'type' => 'string', ), ), ), ), 'nextToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeCommunicationsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'communications' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Communication', 'type' => 'object', 'properties' => array( 'caseId' => array( 'type' => 'string', ), 'body' => array( 'type' => 'string', ), 'submittedBy' => array( 'type' => 'string', ), 'timeCreated' => array( 'type' => 'string', ), ), ), ), 'nextToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DescribeServicesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'services' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Service', 'type' => 'object', 'properties' => array( 'code' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'categories' => array( 'type' => 'array', 'items' => array( 'name' => 'Category', 'type' => 'object', 'properties' => array( 'code' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeSeverityLevelsResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'severityLevels' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'SeverityLevel', 'type' => 'object', 'properties' => array( 'code' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), ), ), ), ), ), 'DescribeTrustedAdvisorCheckRefreshStatusesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'statuses' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TrustedAdvisorCheckRefreshStatus', 'type' => 'object', 'properties' => array( 'checkId' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'millisUntilNextRefreshable' => array( 'type' => 'numeric', ), ), ), ), ), ), 'DescribeTrustedAdvisorCheckResultResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'result' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'checkId' => array( 'type' => 'string', ), 'timestamp' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'resourcesSummary' => array( 'type' => 'object', 'properties' => array( 'resourcesProcessed' => array( 'type' => 'numeric', ), 'resourcesFlagged' => array( 'type' => 'numeric', ), 'resourcesIgnored' => array( 'type' => 'numeric', ), 'resourcesSuppressed' => array( 'type' => 'numeric', ), ), ), 'categorySpecificSummary' => array( 'type' => 'object', 'properties' => array( 'costOptimizing' => array( 'type' => 'object', 'properties' => array( 'estimatedMonthlySavings' => array( 'type' => 'numeric', ), 'estimatedPercentMonthlySavings' => array( 'type' => 'numeric', ), ), ), ), ), 'flaggedResources' => array( 'type' => 'array', 'items' => array( 'name' => 'TrustedAdvisorResourceDetail', 'type' => 'object', 'properties' => array( 'status' => array( 'type' => 'string', ), 'region' => array( 'type' => 'string', ), 'resourceId' => array( 'type' => 'string', ), 'isSuppressed' => array( 'type' => 'boolean', ), 'metadata' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), ), ), ), ), 'DescribeTrustedAdvisorCheckSummariesResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'summaries' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TrustedAdvisorCheckSummary', 'type' => 'object', 'properties' => array( 'checkId' => array( 'type' => 'string', ), 'timestamp' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'hasFlaggedResources' => array( 'type' => 'boolean', ), 'resourcesSummary' => array( 'type' => 'object', 'properties' => array( 'resourcesProcessed' => array( 'type' => 'numeric', ), 'resourcesFlagged' => array( 'type' => 'numeric', ), 'resourcesIgnored' => array( 'type' => 'numeric', ), 'resourcesSuppressed' => array( 'type' => 'numeric', ), ), ), 'categorySpecificSummary' => array( 'type' => 'object', 'properties' => array( 'costOptimizing' => array( 'type' => 'object', 'properties' => array( 'estimatedMonthlySavings' => array( 'type' => 'numeric', ), 'estimatedPercentMonthlySavings' => array( 'type' => 'numeric', ), ), ), ), ), ), ), ), ), ), 'DescribeTrustedAdvisorChecksResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'checks' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'TrustedAdvisorCheckDescription', 'type' => 'object', 'properties' => array( 'id' => array( 'type' => 'string', ), 'name' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'category' => array( 'type' => 'string', ), 'metadata' => array( 'type' => 'array', 'items' => array( 'name' => 'String', 'type' => 'string', ), ), ), ), ), ), ), 'RefreshTrustedAdvisorCheckResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'status' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'checkId' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'millisUntilNextRefreshable' => array( 'type' => 'numeric', ), ), ), ), ), 'ResolveCaseResponse' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'initialCaseStatus' => array( 'type' => 'string', 'location' => 'json', ), 'finalCaseStatus' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'DescribeCases' => array( 'token_param' => 'nextToken', 'token_key' => 'nextToken', 'limit_key' => 'maxResults', 'result_key' => 'cases', ), 'DescribeCommunications' => array( 'token_param' => 'nextToken', 'token_key' => 'nextToken', 'limit_key' => 'maxResults', 'result_key' => 'communications', ), 'DescribeServices' => array( 'result_key' => 'services', ), 'DescribeTrustedAdvisorCheckRefreshStatuses' => array( 'result_key' => 'statuses', ), 'DescribeTrustedAdvisorCheckSummaries' => array( 'result_key' => 'summaries', ), 'DescribeSeverityLevels' => array( 'result_key' => 'severityLevelsList', ), 'DescribeTrustedAdvisorChecks' => array( 'result_key' => 'checks', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/support-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } '2012-01-25', 'endpointPrefix' => 'swf', 'serviceFullName' => 'Amazon Simple Workflow Service', 'serviceAbbreviation' => 'Amazon SWF', 'serviceType' => 'json', 'jsonVersion' => '1.0', 'targetPrefix' => 'SimpleWorkflowService.', 'timestampFormat' => 'unixTimestamp', 'signatureVersion' => 'v4', 'namespace' => 'Swf', 'regions' => array( 'us-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.us-east-1.amazonaws.com', ), 'us-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.us-west-1.amazonaws.com', ), 'us-west-2' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.us-west-2.amazonaws.com', ), 'eu-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.eu-west-1.amazonaws.com', ), 'ap-northeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.ap-northeast-1.amazonaws.com', ), 'ap-southeast-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.ap-southeast-1.amazonaws.com', ), 'ap-southeast-2' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.ap-southeast-2.amazonaws.com', ), 'sa-east-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.sa-east-1.amazonaws.com', ), 'cn-north-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.cn-north-1.amazonaws.com.cn', ), 'us-gov-west-1' => array( 'http' => false, 'https' => true, 'hostname' => 'swf.us-gov-west-1.amazonaws.com', ), ), 'operations' => array( 'CountClosedWorkflowExecutions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionCount', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.CountClosedWorkflowExecutions', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'startTimeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'closeTimeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'executionFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'typeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), 'tagFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'tag' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'closeStatusFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'status' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'COMPLETED', 'FAILED', 'CANCELED', 'TERMINATED', 'CONTINUED_AS_NEW', 'TIMED_OUT', ), ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'CountOpenWorkflowExecutions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionCount', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.CountOpenWorkflowExecutions', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'startTimeFilter' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'typeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), 'tagFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'tag' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'executionFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'CountPendingActivityTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PendingTaskCount', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.CountPendingActivityTasks', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'taskList' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'CountPendingDecisionTasks' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'PendingTaskCount', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.CountPendingDecisionTasks', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'taskList' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DeprecateActivityType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DeprecateActivityType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'activityType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the specified activity or workflow type was already deprecated.', 'class' => 'TypeDeprecatedException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DeprecateDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DeprecateDomain', ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the specified domain has been deprecated.', 'class' => 'DomainDeprecatedException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DeprecateWorkflowType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DeprecateWorkflowType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the specified activity or workflow type was already deprecated.', 'class' => 'TypeDeprecatedException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DescribeActivityType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivityTypeDetail', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DescribeActivityType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'activityType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DescribeDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DomainDetail', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DescribeDomain', ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DescribeWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionDetail', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DescribeWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'execution' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'DescribeWorkflowType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowTypeDetail', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.DescribeWorkflowType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'GetWorkflowExecutionHistory' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'History', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.GetWorkflowExecutionHistory', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'execution' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'ListActivityTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivityTypeInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListActivityTypes', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'registrationStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'enum' => array( 'REGISTERED', 'DEPRECATED', ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), ), ), 'ListClosedWorkflowExecutions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListClosedWorkflowExecutions', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'startTimeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'closeTimeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'executionFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'closeStatusFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'status' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'COMPLETED', 'FAILED', 'CANCELED', 'TERMINATED', 'CONTINUED_AS_NEW', 'TIMED_OUT', ), ), ), ), 'typeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), 'tagFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'tag' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'ListDomains' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DomainInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListDomains', ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'registrationStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'enum' => array( 'REGISTERED', 'DEPRECATED', ), ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'ListOpenWorkflowExecutions' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowExecutionInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListOpenWorkflowExecutions', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'startTimeFilter' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'oldestDate' => array( 'required' => true, 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), 'latestDate' => array( 'type' => array( 'object', 'string', 'integer', ), 'format' => 'timestamp', ), ), ), 'typeFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'type' => 'string', 'maxLength' => 64, ), ), ), 'tagFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'tag' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), 'executionFilter' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'ListWorkflowTypes' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'WorkflowTypeInfos', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.ListWorkflowTypes', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'name' => array( 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'registrationStatus' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'enum' => array( 'REGISTERED', 'DEPRECATED', ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), ), ), 'PollForActivityTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivityTask', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.PollForActivityTask', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'taskList' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'identity' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), ), ), 'PollForDecisionTask' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'DecisionTask', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.PollForDecisionTask', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'taskList' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'identity' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), 'maximumPageSize' => array( 'type' => 'numeric', 'location' => 'json', 'maximum' => 1000, ), 'reverseOrder' => array( 'type' => 'boolean', 'format' => 'boolean-string', 'location' => 'json', ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), ), ), 'RecordActivityTaskHeartbeat' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'ActivityTaskStatus', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RecordActivityTaskHeartbeat', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'details' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 2048, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RegisterActivityType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RegisterActivityType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 64, ), 'description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'defaultTaskStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultTaskHeartbeatTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultTaskList' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'defaultTaskScheduleToStartTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultTaskScheduleToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the type already exists in the specified domain. You will get this fault even if the existing type is in deprecated status. You can specify another version if the intent is to create a new distinct version of the type.', 'class' => 'TypeAlreadyExistsException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RegisterDomain' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RegisterDomain', ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'workflowExecutionRetentionPeriodInDays' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 8, ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the specified domain already exists. You will get this fault even if the existing domain is in deprecated status.', 'class' => 'DomainAlreadyExistsException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RegisterWorkflowType' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RegisterWorkflowType', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'name' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 64, ), 'description' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 1024, ), 'defaultTaskStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultExecutionStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'defaultTaskList' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'defaultChildPolicy' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned if the type already exists in the specified domain. You will get this fault even if the existing type is in deprecated status. You can specify another version if the intent is to create a new distinct version of the type.', 'class' => 'TypeAlreadyExistsException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RequestCancelWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RequestCancelWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 64, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RespondActivityTaskCanceled' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RespondActivityTaskCanceled', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'details' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RespondActivityTaskCompleted' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RespondActivityTaskCompleted', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'result' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RespondActivityTaskFailed' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RespondActivityTaskFailed', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'reason' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'details' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'RespondDecisionTaskCompleted' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.RespondDecisionTaskCompleted', ), 'taskToken' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 1024, ), 'decisions' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'Decision', 'type' => 'object', 'properties' => array( 'decisionType' => array( 'required' => true, 'type' => 'string', 'enum' => array( 'ScheduleActivityTask', 'RequestCancelActivityTask', 'CompleteWorkflowExecution', 'FailWorkflowExecution', 'CancelWorkflowExecution', 'ContinueAsNewWorkflowExecution', 'RecordMarker', 'StartTimer', 'CancelTimer', 'SignalExternalWorkflowExecution', 'RequestCancelExternalWorkflowExecution', 'StartChildWorkflowExecution', ), ), 'scheduleActivityTaskDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'activityId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), 'input' => array( 'type' => 'string', 'maxLength' => 32768, ), 'scheduleToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'scheduleToStartTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'startToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'heartbeatTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), ), ), 'requestCancelActivityTaskDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'activityId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'completeWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'failWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', 'maxLength' => 256, ), 'details' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'cancelWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'continueAsNewWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', 'maxLength' => 32768, ), 'executionStartToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'childPolicy' => array( 'type' => 'string', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), 'tagList' => array( 'type' => 'array', 'maxItems' => 5, 'items' => array( 'name' => 'Tag', 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), 'workflowTypeVersion' => array( 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'recordMarkerDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'details' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'startTimerDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), 'startToFireTimeout' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 8, ), ), ), 'cancelTimerDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'signalExternalWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'maxLength' => 64, ), 'signalName' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'input' => array( 'type' => 'string', 'maxLength' => 32768, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'requestCancelExternalWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'maxLength' => 64, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), ), ), 'startChildWorkflowExecutionDecisionAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowType' => array( 'required' => true, 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'control' => array( 'type' => 'string', 'maxLength' => 32768, ), 'input' => array( 'type' => 'string', 'maxLength' => 32768, ), 'executionStartToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', 'maxLength' => 8, ), 'childPolicy' => array( 'type' => 'string', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), 'tagList' => array( 'type' => 'array', 'maxItems' => 5, 'items' => array( 'name' => 'Tag', 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), ), ), ), ), 'executionContext' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'SignalWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.SignalWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 64, ), 'signalName' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'input' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), 'StartWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'Run', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.StartWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowType' => array( 'required' => true, 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), 'version' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 64, ), ), ), 'taskList' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'required' => true, 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), ), 'input' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), 'executionStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'tagList' => array( 'type' => 'array', 'location' => 'json', 'maxItems' => 5, 'items' => array( 'name' => 'Tag', 'type' => 'string', 'minLength' => 1, 'maxLength' => 256, ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 8, ), 'childPolicy' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the specified activity or workflow type was already deprecated.', 'class' => 'TypeDeprecatedException', ), array( 'reason' => 'Returned by StartWorkflowExecution when an open execution with the same workflowId is already running in the specified domain.', 'class' => 'WorkflowExecutionAlreadyStartedException', ), array( 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', 'class' => 'LimitExceededException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), array( 'class' => 'DefaultUndefinedException', ), ), ), 'TerminateWorkflowExecution' => array( 'httpMethod' => 'POST', 'uri' => '/', 'class' => 'Aws\\Common\\Command\\JsonCommand', 'responseClass' => 'EmptyOutput', 'responseType' => 'model', 'parameters' => array( 'Content-Type' => array( 'static' => true, 'location' => 'header', 'default' => 'application/x-amz-json-1.0', ), 'command.expects' => array( 'static' => true, 'default' => 'application/json', ), 'X-Amz-Target' => array( 'static' => true, 'location' => 'header', 'default' => 'SimpleWorkflowService.TerminateWorkflowExecution', ), 'domain' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'workflowId' => array( 'required' => true, 'type' => 'string', 'location' => 'json', 'minLength' => 1, 'maxLength' => 256, ), 'runId' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 64, ), 'reason' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 256, ), 'details' => array( 'type' => 'string', 'location' => 'json', 'maxLength' => 32768, ), 'childPolicy' => array( 'type' => 'string', 'location' => 'json', 'enum' => array( 'TERMINATE', 'REQUEST_CANCEL', 'ABANDON', ), ), ), 'errorResponses' => array( array( 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', 'class' => 'UnknownResourceException', ), array( 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', 'class' => 'OperationNotPermittedException', ), ), ), ), 'models' => array( 'WorkflowExecutionCount' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'count' => array( 'type' => 'numeric', 'location' => 'json', ), 'truncated' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'PendingTaskCount' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'count' => array( 'type' => 'numeric', 'location' => 'json', ), 'truncated' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'EmptyOutput' => array( 'type' => 'object', 'additionalProperties' => true, ), 'ActivityTypeDetail' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'typeInfo' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'creationDate' => array( 'type' => 'string', ), 'deprecationDate' => array( 'type' => 'string', ), ), ), 'configuration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'defaultTaskStartToCloseTimeout' => array( 'type' => 'string', ), 'defaultTaskHeartbeatTimeout' => array( 'type' => 'string', ), 'defaultTaskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'defaultTaskScheduleToStartTimeout' => array( 'type' => 'string', ), 'defaultTaskScheduleToCloseTimeout' => array( 'type' => 'string', ), ), ), ), ), 'DomainDetail' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'domainInfo' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), ), ), 'configuration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowExecutionRetentionPeriodInDays' => array( 'type' => 'string', ), ), ), ), ), 'WorkflowExecutionDetail' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'executionInfo' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'execution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'startTimestamp' => array( 'type' => 'string', ), 'closeTimestamp' => array( 'type' => 'string', ), 'executionStatus' => array( 'type' => 'string', ), 'closeStatus' => array( 'type' => 'string', ), 'parent' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'cancelRequested' => array( 'type' => 'boolean', ), ), ), 'executionConfiguration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'childPolicy' => array( 'type' => 'string', ), ), ), 'openCounts' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'openActivityTasks' => array( 'type' => 'numeric', ), 'openDecisionTasks' => array( 'type' => 'numeric', ), 'openTimers' => array( 'type' => 'numeric', ), 'openChildWorkflowExecutions' => array( 'type' => 'numeric', ), ), ), 'latestActivityTaskTimestamp' => array( 'type' => 'string', 'location' => 'json', ), 'latestExecutionContext' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'WorkflowTypeDetail' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'typeInfo' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'creationDate' => array( 'type' => 'string', ), 'deprecationDate' => array( 'type' => 'string', ), ), ), 'configuration' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'defaultTaskStartToCloseTimeout' => array( 'type' => 'string', ), 'defaultExecutionStartToCloseTimeout' => array( 'type' => 'string', ), 'defaultTaskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'defaultChildPolicy' => array( 'type' => 'string', ), ), ), ), ), 'History' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'events' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'HistoryEvent', 'type' => 'object', 'properties' => array( 'eventTimestamp' => array( 'type' => 'string', ), 'eventType' => array( 'type' => 'string', ), 'eventId' => array( 'type' => 'numeric', ), 'workflowExecutionStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'continuedExecutionRunId' => array( 'type' => 'string', ), 'parentWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'parentInitiatedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'completeWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'failWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), ), ), 'workflowExecutionCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'cancelWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionContinuedAsNewEventAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'newExecutionRunId' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), ), ), 'continueAsNewWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionTerminatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), ), ), 'workflowExecutionCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'externalWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'externalInitiatedEventId' => array( 'type' => 'numeric', ), 'cause' => array( 'type' => 'string', ), ), ), 'decisionTaskScheduledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'startToCloseTimeout' => array( 'type' => 'string', ), ), ), 'decisionTaskStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'identity' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), ), ), 'decisionTaskCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'executionContext' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'decisionTaskTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskScheduledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'activityId' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'control' => array( 'type' => 'string', ), 'scheduleToStartTimeout' => array( 'type' => 'string', ), 'scheduleToCloseTimeout' => array( 'type' => 'string', ), 'startToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'heartbeatTimeout' => array( 'type' => 'string', ), ), ), 'activityTaskStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'identity' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), 'details' => array( 'type' => 'string', ), ), ), 'activityTaskCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), 'latestCancelRequestedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'activityId' => array( 'type' => 'string', ), ), ), 'workflowExecutionSignaledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'signalName' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'externalWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'externalInitiatedEventId' => array( 'type' => 'numeric', ), ), ), 'markerRecordedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'recordMarkerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'timerStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'control' => array( 'type' => 'string', ), 'startToFireTimeout' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'timerFiredEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'timerCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'startedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startChildWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'control' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'childPolicy' => array( 'type' => 'string', ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), ), ), 'childWorkflowExecutionStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'result' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'timeoutType' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'details' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionTerminatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'signalExternalWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'signalName' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'externalWorkflowExecutionSignaledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'signalExternalWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'externalWorkflowExecutionCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'requestCancelExternalWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'requestCancelExternalWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'scheduleActivityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'activityId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'requestCancelActivityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startTimerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'cancelTimerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startChildWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'cause' => array( 'type' => 'string', ), 'workflowId' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ActivityTypeInfos' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'typeInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'ActivityTypeInfo', 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'creationDate' => array( 'type' => 'string', ), 'deprecationDate' => array( 'type' => 'string', ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'WorkflowExecutionInfos' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'executionInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'WorkflowExecutionInfo', 'type' => 'object', 'properties' => array( 'execution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'startTimestamp' => array( 'type' => 'string', ), 'closeTimestamp' => array( 'type' => 'string', ), 'executionStatus' => array( 'type' => 'string', ), 'closeStatus' => array( 'type' => 'string', ), 'parent' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'cancelRequested' => array( 'type' => 'boolean', ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DomainInfos' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'domainInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'DomainInfo', 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'WorkflowTypeInfos' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'typeInfos' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'WorkflowTypeInfo', 'type' => 'object', 'properties' => array( 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'status' => array( 'type' => 'string', ), 'description' => array( 'type' => 'string', ), 'creationDate' => array( 'type' => 'string', ), 'deprecationDate' => array( 'type' => 'string', ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'ActivityTask' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'taskToken' => array( 'type' => 'string', 'location' => 'json', ), 'activityId' => array( 'type' => 'string', 'location' => 'json', ), 'startedEventId' => array( 'type' => 'numeric', 'location' => 'json', ), 'workflowExecution' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'activityType' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'input' => array( 'type' => 'string', 'location' => 'json', ), ), ), 'DecisionTask' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'taskToken' => array( 'type' => 'string', 'location' => 'json', ), 'startedEventId' => array( 'type' => 'numeric', 'location' => 'json', ), 'workflowExecution' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'location' => 'json', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'events' => array( 'type' => 'array', 'location' => 'json', 'items' => array( 'name' => 'HistoryEvent', 'type' => 'object', 'properties' => array( 'eventTimestamp' => array( 'type' => 'string', ), 'eventType' => array( 'type' => 'string', ), 'eventId' => array( 'type' => 'numeric', ), 'workflowExecutionStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'continuedExecutionRunId' => array( 'type' => 'string', ), 'parentWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'parentInitiatedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'completeWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'failWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), ), ), 'workflowExecutionCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'cancelWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionContinuedAsNewEventAttributes' => array( 'type' => 'object', 'properties' => array( 'input' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'newExecutionRunId' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), ), ), 'continueAsNewWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'workflowExecutionTerminatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'childPolicy' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), ), ), 'workflowExecutionCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'externalWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'externalInitiatedEventId' => array( 'type' => 'numeric', ), 'cause' => array( 'type' => 'string', ), ), ), 'decisionTaskScheduledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'startToCloseTimeout' => array( 'type' => 'string', ), ), ), 'decisionTaskStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'identity' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), ), ), 'decisionTaskCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'executionContext' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'decisionTaskTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskScheduledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'activityId' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'control' => array( 'type' => 'string', ), 'scheduleToStartTimeout' => array( 'type' => 'string', ), 'scheduleToCloseTimeout' => array( 'type' => 'string', ), 'startToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'heartbeatTimeout' => array( 'type' => 'string', ), ), ), 'activityTaskStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'identity' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'result' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timeoutType' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), 'details' => array( 'type' => 'string', ), ), ), 'activityTaskCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'details' => array( 'type' => 'string', ), 'scheduledEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), 'latestCancelRequestedEventId' => array( 'type' => 'numeric', ), ), ), 'activityTaskCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'activityId' => array( 'type' => 'string', ), ), ), 'workflowExecutionSignaledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'signalName' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'externalWorkflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'externalInitiatedEventId' => array( 'type' => 'numeric', ), ), ), 'markerRecordedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'recordMarkerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'markerName' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'timerStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'control' => array( 'type' => 'string', ), 'startToFireTimeout' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'timerFiredEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'timerCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'startedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startChildWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'control' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'executionStartToCloseTimeout' => array( 'type' => 'string', ), 'taskList' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), ), ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'childPolicy' => array( 'type' => 'string', ), 'taskStartToCloseTimeout' => array( 'type' => 'string', ), 'tagList' => array( 'type' => 'array', 'items' => array( 'name' => 'Tag', 'type' => 'string', ), ), ), ), 'childWorkflowExecutionStartedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionCompletedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'result' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'reason' => array( 'type' => 'string', ), 'details' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionTimedOutEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'timeoutType' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionCanceledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'details' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'childWorkflowExecutionTerminatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'startedEventId' => array( 'type' => 'numeric', ), ), ), 'signalExternalWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'signalName' => array( 'type' => 'string', ), 'input' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'externalWorkflowExecutionSignaledEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'signalExternalWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'externalWorkflowExecutionCancelRequestedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowExecution' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), ), ), 'initiatedEventId' => array( 'type' => 'numeric', ), ), ), 'requestCancelExternalWorkflowExecutionInitiatedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'requestCancelExternalWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowId' => array( 'type' => 'string', ), 'runId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), 'scheduleActivityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'activityId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'requestCancelActivityTaskFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'activityId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startTimerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'cancelTimerFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'timerId' => array( 'type' => 'string', ), 'cause' => array( 'type' => 'string', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), ), ), 'startChildWorkflowExecutionFailedEventAttributes' => array( 'type' => 'object', 'properties' => array( 'workflowType' => array( 'type' => 'object', 'properties' => array( 'name' => array( 'type' => 'string', ), 'version' => array( 'type' => 'string', ), ), ), 'cause' => array( 'type' => 'string', ), 'workflowId' => array( 'type' => 'string', ), 'initiatedEventId' => array( 'type' => 'numeric', ), 'decisionTaskCompletedEventId' => array( 'type' => 'numeric', ), 'control' => array( 'type' => 'string', ), ), ), ), ), ), 'nextPageToken' => array( 'type' => 'string', 'location' => 'json', ), 'previousStartedEventId' => array( 'type' => 'numeric', 'location' => 'json', ), ), ), 'ActivityTaskStatus' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'cancelRequested' => array( 'type' => 'boolean', 'location' => 'json', ), ), ), 'Run' => array( 'type' => 'object', 'additionalProperties' => true, 'properties' => array( 'runId' => array( 'type' => 'string', 'location' => 'json', ), ), ), ), 'iterators' => array( 'operations' => array( 'GetWorkflowExecutionHistory' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'events', ), 'ListActivityTypes' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'typeInfos', ), 'ListClosedWorkflowExecutions' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'executionInfos', ), 'ListDomains' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'domainInfos', ), 'ListOpenWorkflowExecutions' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'executionInfos', ), 'ListWorkflowTypes' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'typeInfos', ), 'PollForDecisionTask' => array( 'token_param' => 'nextPageToken', 'token_key' => 'nextPageToken', 'limit_key' => 'maximumPageSize', 'result_key' => 'events', ), ), ), ); setConfig($config) ->setConfigDefaults(array( Options::VERSION => self::LATEST_API_VERSION, Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/swf-%s.php' )) ->setExceptionParser(new JsonQueryExceptionParser()) ->build(); } } registerNamespaces(array( 'Aws' => AWS_FILE_PREFIX, 'Guzzle' => AWS_FILE_PREFIX, 'Symfony' => AWS_FILE_PREFIX, 'Doctrine' => AWS_FILE_PREFIX, 'Psr' => AWS_FILE_PREFIX, 'Monolog' => AWS_FILE_PREFIX )); $classLoader->register(); return $classLoader; . */ namespace Doctrine\Common\Cache; /** * APC cache provider. * * @link www.doctrine-project.org * @since 2.0 * @author Benjamin Eberlei * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author David Abdemoulaie */ class ApcCache extends CacheProvider { /** * {@inheritdoc} */ protected function doFetch($id) { return apc_fetch($id); } /** * {@inheritdoc} */ protected function doContains($id) { return apc_exists($id); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { return (bool) apc_store($id, $data, (int) $lifeTime); } /** * {@inheritdoc} */ protected function doDelete($id) { return apc_delete($id); } /** * {@inheritdoc} */ protected function doFlush() { return apc_clear_cache() && apc_clear_cache('user'); } /** * {@inheritdoc} */ protected function doGetStats() { $info = apc_cache_info(); $sma = apc_sma_info(); // @TODO - Temporary fix @see https://github.com/krakjoe/apcu/pull/42 if (PHP_VERSION_ID >= 50500) { $info['num_hits'] = isset($info['num_hits']) ? $info['num_hits'] : $info['nhits']; $info['num_misses'] = isset($info['num_misses']) ? $info['num_misses'] : $info['nmisses']; $info['start_time'] = isset($info['start_time']) ? $info['start_time'] : $info['stime']; } return array( Cache::STATS_HITS => $info['num_hits'], Cache::STATS_MISSES => $info['num_misses'], Cache::STATS_UPTIME => $info['start_time'], Cache::STATS_MEMORY_USAGE => $info['mem_size'], Cache::STATS_MEMORY_AVAILABLE => $sma['avail_mem'], ); } } . */ namespace Doctrine\Common\Cache; /** * Array cache driver. * * @link www.doctrine-project.org * @since 2.0 * @author Benjamin Eberlei * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author David Abdemoulaie */ class ArrayCache extends CacheProvider { /** * @var array $data */ private $data = array(); /** * {@inheritdoc} */ protected function doFetch($id) { return (isset($this->data[$id])) ? $this->data[$id] : false; } /** * {@inheritdoc} */ protected function doContains($id) { return isset($this->data[$id]); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { $this->data[$id] = $data; return true; } /** * {@inheritdoc} */ protected function doDelete($id) { unset($this->data[$id]); return true; } /** * {@inheritdoc} */ protected function doFlush() { $this->data = array(); return true; } /** * {@inheritdoc} */ protected function doGetStats() { return null; } } . */ namespace Doctrine\Common\Cache; /** * Interface for cache drivers. * * @link www.doctrine-project.org * @since 2.0 * @author Benjamin Eberlei * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author Fabio B. Silva */ interface Cache { const STATS_HITS = 'hits'; const STATS_MISSES = 'misses'; const STATS_UPTIME = 'uptime'; const STATS_MEMORY_USAGE = 'memory_usage'; const STATS_MEMORY_AVAILABLE = 'memory_available'; /** * Only for backward compatibility (may be removed in next major release) * * @deprecated */ const STATS_MEMORY_AVAILIABLE = 'memory_available'; /** * Fetches an entry from the cache. * * @param string $id The id of the cache entry to fetch. * * @return mixed The cached data or FALSE, if no cache entry exists for the given id. */ function fetch($id); /** * Tests if an entry exists in the cache. * * @param string $id The cache id of the entry to check for. * * @return boolean TRUE if a cache entry exists for the given cache id, FALSE otherwise. */ function contains($id); /** * Puts data into the cache. * * @param string $id The cache id. * @param mixed $data The cache entry/data. * @param int $lifeTime The cache lifetime. * If != 0, sets a specific lifetime for this cache entry (0 => infinite lifeTime). * * @return boolean TRUE if the entry was successfully stored in the cache, FALSE otherwise. */ function save($id, $data, $lifeTime = 0); /** * Deletes a cache entry. * * @param string $id The cache id. * * @return boolean TRUE if the cache entry was successfully deleted, FALSE otherwise. */ function delete($id); /** * Retrieves cached information from the data store. * * The server's statistics array has the following values: * * - hits * Number of keys that have been requested and found present. * * - misses * Number of items that have been requested and not found. * * - uptime * Time that the server is running. * * - memory_usage * Memory used by this server to store items. * * - memory_available * Memory allowed to use for storage. * * @since 2.2 * * @return array|null An associative array with server's statistics if available, NULL otherwise. */ function getStats(); } . */ namespace Doctrine\Common\Cache; /** * Base class for cache provider implementations. * * @since 2.2 * @author Benjamin Eberlei * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author Fabio B. Silva */ abstract class CacheProvider implements Cache { const DOCTRINE_NAMESPACE_CACHEKEY = 'DoctrineNamespaceCacheKey[%s]'; /** * The namespace to prefix all cache ids with. * * @var string */ private $namespace = ''; /** * The namespace version. * * @var string */ private $namespaceVersion; /** * Sets the namespace to prefix all cache ids with. * * @param string $namespace * * @return void */ public function setNamespace($namespace) { $this->namespace = (string) $namespace; $this->namespaceVersion = null; } /** * Retrieves the namespace that prefixes all cache ids. * * @return string */ public function getNamespace() { return $this->namespace; } /** * {@inheritdoc} */ public function fetch($id) { return $this->doFetch($this->getNamespacedId($id)); } /** * {@inheritdoc} */ public function contains($id) { return $this->doContains($this->getNamespacedId($id)); } /** * {@inheritdoc} */ public function save($id, $data, $lifeTime = 0) { return $this->doSave($this->getNamespacedId($id), $data, $lifeTime); } /** * {@inheritdoc} */ public function delete($id) { return $this->doDelete($this->getNamespacedId($id)); } /** * {@inheritdoc} */ public function getStats() { return $this->doGetStats(); } /** * Flushes all cache entries. * * @return boolean TRUE if the cache entries were successfully flushed, FALSE otherwise. */ public function flushAll() { return $this->doFlush(); } /** * Deletes all cache entries. * * @return boolean TRUE if the cache entries were successfully deleted, FALSE otherwise. */ public function deleteAll() { $namespaceCacheKey = $this->getNamespaceCacheKey(); $namespaceVersion = $this->getNamespaceVersion() + 1; $this->namespaceVersion = $namespaceVersion; return $this->doSave($namespaceCacheKey, $namespaceVersion); } /** * Prefixes the passed id with the configured namespace value. * * @param string $id The id to namespace. * * @return string The namespaced id. */ private function getNamespacedId($id) { $namespaceVersion = $this->getNamespaceVersion(); return sprintf('%s[%s][%s]', $this->namespace, $id, $namespaceVersion); } /** * Returns the namespace cache key. * * @return string */ private function getNamespaceCacheKey() { return sprintf(self::DOCTRINE_NAMESPACE_CACHEKEY, $this->namespace); } /** * Returns the namespace version. * * @return string */ private function getNamespaceVersion() { if (null !== $this->namespaceVersion) { return $this->namespaceVersion; } $namespaceCacheKey = $this->getNamespaceCacheKey(); $namespaceVersion = $this->doFetch($namespaceCacheKey); if (false === $namespaceVersion) { $namespaceVersion = 1; $this->doSave($namespaceCacheKey, $namespaceVersion); } $this->namespaceVersion = $namespaceVersion; return $this->namespaceVersion; } /** * Fetches an entry from the cache. * * @param string $id The id of the cache entry to fetch. * * @return string|bool The cached data or FALSE, if no cache entry exists for the given id. */ abstract protected function doFetch($id); /** * Tests if an entry exists in the cache. * * @param string $id The cache id of the entry to check for. * * @return boolean TRUE if a cache entry exists for the given cache id, FALSE otherwise. */ abstract protected function doContains($id); /** * Puts data into the cache. * * @param string $id The cache id. * @param string $data The cache entry/data. * @param int $lifeTime The lifetime. If != 0, sets a specific lifetime for this * cache entry (0 => infinite lifeTime). * * @return boolean TRUE if the entry was successfully stored in the cache, FALSE otherwise. */ abstract protected function doSave($id, $data, $lifeTime = 0); /** * Deletes a cache entry. * * @param string $id The cache id. * * @return boolean TRUE if the cache entry was successfully deleted, FALSE otherwise. */ abstract protected function doDelete($id); /** * Flushes all cache entries. * * @return boolean TRUE if the cache entry was successfully deleted, FALSE otherwise. */ abstract protected function doFlush(); /** * Retrieves cached information from the data store. * * @since 2.2 * * @return array|null An associative array with server's statistics if available, NULL otherwise. */ abstract protected function doGetStats(); } . */ namespace Doctrine\Common\Cache; use \Couchbase; /** * Couchbase cache provider. * * @link www.doctrine-project.org * @since 2.4 * @author Michael Nitschinger */ class CouchbaseCache extends CacheProvider { /** * @var Couchbase|null */ private $couchbase; /** * Sets the Couchbase instance to use. * * @param Couchbase $couchbase * * @return void */ public function setCouchbase(Couchbase $couchbase) { $this->couchbase = $couchbase; } /** * Gets the Couchbase instance used by the cache. * * @return Couchbase|null */ public function getCouchbase() { return $this->couchbase; } /** * {@inheritdoc} */ protected function doFetch($id) { return $this->couchbase->get($id) ?: false; } /** * {@inheritdoc} */ protected function doContains($id) { return (null !== $this->couchbase->get($id)); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { if ($lifeTime > 30 * 24 * 3600) { $lifeTime = time() + $lifeTime; } return $this->couchbase->set($id, $data, (int) $lifeTime); } /** * {@inheritdoc} */ protected function doDelete($id) { return $this->couchbase->delete($id); } /** * {@inheritdoc} */ protected function doFlush() { return $this->couchbase->flush(); } /** * {@inheritdoc} */ protected function doGetStats() { $stats = $this->couchbase->getStats(); $servers = $this->couchbase->getServers(); $server = explode(":", $servers[0]); $key = $server[0] . ":" . "11210"; $stats = $stats[$key]; return array( Cache::STATS_HITS => $stats['get_hits'], Cache::STATS_MISSES => $stats['get_misses'], Cache::STATS_UPTIME => $stats['uptime'], Cache::STATS_MEMORY_USAGE => $stats['bytes'], Cache::STATS_MEMORY_AVAILABLE => $stats['limit_maxbytes'], ); } } . */ namespace Doctrine\Common\Cache; /** * Base file cache driver. * * @since 2.3 * @author Fabio B. Silva */ abstract class FileCache extends CacheProvider { /** * The cache directory. * * @var string */ protected $directory; /** * The cache file extension. * * @var string|null */ protected $extension; /** * Constructor. * * @param string $directory The cache directory. * @param string|null $extension The cache file extension. * * @throws \InvalidArgumentException */ public function __construct($directory, $extension = null) { if ( ! is_dir($directory) && ! @mkdir($directory, 0777, true)) { throw new \InvalidArgumentException(sprintf( 'The directory "%s" does not exist and could not be created.', $directory )); } if ( ! is_writable($directory)) { throw new \InvalidArgumentException(sprintf( 'The directory "%s" is not writable.', $directory )); } $this->directory = realpath($directory); $this->extension = $extension ?: $this->extension; } /** * Gets the cache directory. * * @return string */ public function getDirectory() { return $this->directory; } /** * Gets the cache file extension. * * @return string|null */ public function getExtension() { return $this->extension; } /** * @param string $id * * @return string */ protected function getFilename($id) { $hash = hash('sha256', $id); $path = implode(str_split($hash, 16), DIRECTORY_SEPARATOR); $path = $this->directory . DIRECTORY_SEPARATOR . $path; $id = preg_replace('@[\\\/:"*?<>|]+@', '', $id); return $path . DIRECTORY_SEPARATOR . $id . $this->extension; } /** * {@inheritdoc} */ protected function doDelete($id) { return @unlink($this->getFilename($id)); } /** * {@inheritdoc} */ protected function doFlush() { foreach ($this->getIterator() as $name => $file) { @unlink($name); } return true; } /** * {@inheritdoc} */ protected function doGetStats() { $usage = 0; foreach ($this->getIterator() as $name => $file) { $usage += $file->getSize(); } $free = disk_free_space($this->directory); return array( Cache::STATS_HITS => null, Cache::STATS_MISSES => null, Cache::STATS_UPTIME => null, Cache::STATS_MEMORY_USAGE => $usage, Cache::STATS_MEMORY_AVAILABLE => $free, ); } /** * @return \Iterator */ private function getIterator() { $pattern = '/^.+\\' . $this->extension . '$/i'; $iterator = new \RecursiveDirectoryIterator($this->directory); $iterator = new \RecursiveIteratorIterator($iterator); return new \RegexIterator($iterator, $pattern); } } . */ namespace Doctrine\Common\Cache; /** * Filesystem cache driver. * * @since 2.3 * @author Fabio B. Silva */ class FilesystemCache extends FileCache { const EXTENSION = '.doctrinecache.data'; /** * {@inheritdoc} */ protected $extension = self::EXTENSION; /** * {@inheritdoc} */ protected function doFetch($id) { $data = ''; $lifetime = -1; $filename = $this->getFilename($id); if ( ! is_file($filename)) { return false; } $resource = fopen($filename, "r"); if (false !== ($line = fgets($resource))) { $lifetime = (integer) $line; } if ($lifetime !== 0 && $lifetime < time()) { fclose($resource); return false; } while (false !== ($line = fgets($resource))) { $data .= $line; } fclose($resource); return unserialize($data); } /** * {@inheritdoc} */ protected function doContains($id) { $lifetime = -1; $filename = $this->getFilename($id); if ( ! is_file($filename)) { return false; } $resource = fopen($filename, "r"); if (false !== ($line = fgets($resource))) { $lifetime = (integer) $line; } fclose($resource); return $lifetime === 0 || $lifetime > time(); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { if ($lifeTime > 0) { $lifeTime = time() + $lifeTime; } $data = serialize($data); $filename = $this->getFilename($id); $filepath = pathinfo($filename, PATHINFO_DIRNAME); if ( ! is_dir($filepath)) { mkdir($filepath, 0777, true); } return file_put_contents($filename, $lifeTime . PHP_EOL . $data) !== false; } } . */ namespace Doctrine\Common\Cache; use \Memcache; /** * Memcache cache provider. * * @link www.doctrine-project.org * @since 2.0 * @author Benjamin Eberlei * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author David Abdemoulaie */ class MemcacheCache extends CacheProvider { /** * @var Memcache|null */ private $memcache; /** * Sets the memcache instance to use. * * @param Memcache $memcache * * @return void */ public function setMemcache(Memcache $memcache) { $this->memcache = $memcache; } /** * Gets the memcache instance used by the cache. * * @return Memcache|null */ public function getMemcache() { return $this->memcache; } /** * {@inheritdoc} */ protected function doFetch($id) { return $this->memcache->get($id); } /** * {@inheritdoc} */ protected function doContains($id) { return (bool) $this->memcache->get($id); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { if ($lifeTime > 30 * 24 * 3600) { $lifeTime = time() + $lifeTime; } return $this->memcache->set($id, $data, 0, (int) $lifeTime); } /** * {@inheritdoc} */ protected function doDelete($id) { return $this->memcache->delete($id); } /** * {@inheritdoc} */ protected function doFlush() { return $this->memcache->flush(); } /** * {@inheritdoc} */ protected function doGetStats() { $stats = $this->memcache->getStats(); return array( Cache::STATS_HITS => $stats['get_hits'], Cache::STATS_MISSES => $stats['get_misses'], Cache::STATS_UPTIME => $stats['uptime'], Cache::STATS_MEMORY_USAGE => $stats['bytes'], Cache::STATS_MEMORY_AVAILABLE => $stats['limit_maxbytes'], ); } } . */ namespace Doctrine\Common\Cache; use \Memcached; /** * Memcached cache provider. * * @link www.doctrine-project.org * @since 2.2 * @author Benjamin Eberlei * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author David Abdemoulaie */ class MemcachedCache extends CacheProvider { /** * @var Memcached|null */ private $memcached; /** * Sets the memcache instance to use. * * @param Memcached $memcached * * @return void */ public function setMemcached(Memcached $memcached) { $this->memcached = $memcached; } /** * Gets the memcached instance used by the cache. * * @return Memcached|null */ public function getMemcached() { return $this->memcached; } /** * {@inheritdoc} */ protected function doFetch($id) { return $this->memcached->get($id); } /** * {@inheritdoc} */ protected function doContains($id) { return (false !== $this->memcached->get($id)); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { if ($lifeTime > 30 * 24 * 3600) { $lifeTime = time() + $lifeTime; } return $this->memcached->set($id, $data, (int) $lifeTime); } /** * {@inheritdoc} */ protected function doDelete($id) { return $this->memcached->delete($id); } /** * {@inheritdoc} */ protected function doFlush() { return $this->memcached->flush(); } /** * {@inheritdoc} */ protected function doGetStats() { $stats = $this->memcached->getStats(); $servers = $this->memcached->getServerList(); $key = $servers[0]['host'] . ':' . $servers[0]['port']; $stats = $stats[$key]; return array( Cache::STATS_HITS => $stats['get_hits'], Cache::STATS_MISSES => $stats['get_misses'], Cache::STATS_UPTIME => $stats['uptime'], Cache::STATS_MEMORY_USAGE => $stats['bytes'], Cache::STATS_MEMORY_AVAILABLE => $stats['limit_maxbytes'], ); } } . */ namespace Doctrine\Common\Cache; use MongoBinData; use MongoCollection; use MongoDate; /** * MongoDB cache provider. * * @since 1.1 * @author Jeremy Mikola */ class MongoDBCache extends CacheProvider { /** * The data field will store the serialized PHP value. */ const DATA_FIELD = 'd'; /** * The expiration field will store a MongoDate value indicating when the * cache entry should expire. * * With MongoDB 2.2+, entries can be automatically deleted by MongoDB by * indexing this field wit the "expireAfterSeconds" option equal to zero. * This will direct MongoDB to regularly query for and delete any entries * whose date is older than the current time. Entries without a date value * in this field will be ignored. * * The cache provider will also check dates on its own, in case expired * entries are fetched before MongoDB's TTLMonitor pass can expire them. * * @see http://docs.mongodb.org/manual/tutorial/expire-data/ */ const EXPIRATION_FIELD = 'e'; /** * @var MongoCollection */ private $collection; /** * Constructor. * * This provider will default to the write concern and read preference * options set on the MongoCollection instance (or inherited from MongoDB or * MongoClient). Using an unacknowledged write concern (< 1) may make the * return values of delete() and save() unreliable. Reading from secondaries * may make contain() and fetch() unreliable. * * @see http://www.php.net/manual/en/mongo.readpreferences.php * @see http://www.php.net/manual/en/mongo.writeconcerns.php * @param MongoCollection $collection */ public function __construct(MongoCollection $collection) { $this->collection = $collection; } /** * {@inheritdoc} */ protected function doFetch($id) { $document = $this->collection->findOne(array('_id' => $id), array(self::DATA_FIELD, self::EXPIRATION_FIELD)); if ($document === null) { return false; } if ($this->isExpired($document)) { $this->doDelete($id); return false; } return unserialize($document[self::DATA_FIELD]->bin); } /** * {@inheritdoc} */ protected function doContains($id) { $document = $this->collection->findOne(array('_id' => $id), array(self::EXPIRATION_FIELD)); if ($document === null) { return false; } if ($this->isExpired($document)) { $this->doDelete($id); return false; } return true; } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { $result = $this->collection->update( array('_id' => $id), array('$set' => array( self::EXPIRATION_FIELD => ($lifeTime > 0 ? new MongoDate(time() + $lifeTime) : null), self::DATA_FIELD => new MongoBinData(serialize($data), MongoBinData::BYTE_ARRAY), )), array('upsert' => true, 'multiple' => false) ); return isset($result['ok']) ? $result['ok'] == 1 : true; } /** * {@inheritdoc} */ protected function doDelete($id) { $result = $this->collection->remove(array('_id' => $id)); return isset($result['n']) ? $result['n'] == 1 : true; } /** * {@inheritdoc} */ protected function doFlush() { // Use remove() in lieu of drop() to maintain any collection indexes $result = $this->collection->remove(); return isset($result['ok']) ? $result['ok'] == 1 : true; } /** * {@inheritdoc} */ protected function doGetStats() { $serverStatus = $this->collection->db->command(array( 'serverStatus' => 1, 'locks' => 0, 'metrics' => 0, 'recordStats' => 0, 'repl' => 0, )); $collStats = $this->collection->db->command(array('collStats' => 1)); return array( Cache::STATS_HITS => null, Cache::STATS_MISSES => null, Cache::STATS_UPTIME => (isset($serverStatus['uptime']) ? (integer) $serverStatus['uptime'] : null), Cache::STATS_MEMORY_USAGE => (isset($collStats['size']) ? (integer) $collStats['size'] : null), Cache::STATS_MEMORY_AVAILABLE => null, ); } /** * Check if the document is expired. * * @param array $document * @return boolean */ private function isExpired(array $document) { return isset($document[self::EXPIRATION_FIELD]) && $document[self::EXPIRATION_FIELD] instanceof MongoDate && $document[self::EXPIRATION_FIELD]->sec < time(); } } . */ namespace Doctrine\Common\Cache; /** * Php file cache driver. * * @since 2.3 * @author Fabio B. Silva */ class PhpFileCache extends FileCache { const EXTENSION = '.doctrinecache.php'; /** * {@inheritdoc} */ protected $extension = self::EXTENSION; /** * {@inheritdoc} */ protected function doFetch($id) { $filename = $this->getFilename($id); if ( ! is_file($filename)) { return false; } $value = include $filename; if ($value['lifetime'] !== 0 && $value['lifetime'] < time()) { return false; } return $value['data']; } /** * {@inheritdoc} */ protected function doContains($id) { $filename = $this->getFilename($id); if ( ! is_file($filename)) { return false; } $value = include $filename; return $value['lifetime'] === 0 || $value['lifetime'] > time(); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { if ($lifeTime > 0) { $lifeTime = time() + $lifeTime; } if (is_object($data) && ! method_exists($data, '__set_state')) { throw new \InvalidArgumentException( "Invalid argument given, PhpFileCache only allows objects that implement __set_state() " . "and fully support var_export(). You can use the FilesystemCache to save arbitrary object " . "graphs using serialize()/deserialize()." ); } $filename = $this->getFilename($id); $filepath = pathinfo($filename, PATHINFO_DIRNAME); if ( ! is_dir($filepath)) { mkdir($filepath, 0777, true); } $value = array( 'lifetime' => $lifeTime, 'data' => $data ); $value = var_export($value, true); $code = sprintf('. */ namespace Doctrine\Common\Cache; use Redis; /** * Redis cache provider. * * @link www.doctrine-project.org * @since 2.2 * @author Osman Ungur */ class RedisCache extends CacheProvider { /** * @var Redis|null */ private $redis; /** * Sets the redis instance to use. * * @param Redis $redis * * @return void */ public function setRedis(Redis $redis) { $redis->setOption(Redis::OPT_SERIALIZER, $this->getSerializerValue()); $this->redis = $redis; } /** * Gets the redis instance used by the cache. * * @return Redis|null */ public function getRedis() { return $this->redis; } /** * {@inheritdoc} */ protected function doFetch($id) { return $this->redis->get($id); } /** * {@inheritdoc} */ protected function doContains($id) { return $this->redis->exists($id); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { if ($lifeTime > 0) { return $this->redis->setex($id, $lifeTime, $data); } return $this->redis->set($id, $data); } /** * {@inheritdoc} */ protected function doDelete($id) { return $this->redis->delete($id) > 0; } /** * {@inheritdoc} */ protected function doFlush() { return $this->redis->flushDB(); } /** * {@inheritdoc} */ protected function doGetStats() { $info = $this->redis->info(); return array( Cache::STATS_HITS => false, Cache::STATS_MISSES => false, Cache::STATS_UPTIME => $info['uptime_in_seconds'], Cache::STATS_MEMORY_USAGE => $info['used_memory'], Cache::STATS_MEMORY_AVAILABLE => false ); } /** * Returns the serializer constant to use. If Redis is compiled with * igbinary support, that is used. Otherwise the default PHP serializer is * used. * * @return integer One of the Redis::SERIALIZER_* constants */ protected function getSerializerValue() { return defined('Redis::SERIALIZER_IGBINARY') ? Redis::SERIALIZER_IGBINARY : Redis::SERIALIZER_PHP; } } . */ namespace Doctrine\Common\Cache; use Riak\Bucket; use Riak\Connection; use Riak\Input; use Riak\Exception; use Riak\Object; /** * Riak cache provider. * * @link www.doctrine-project.org * @since 1.1 * @author Guilherme Blanco */ class RiakCache extends CacheProvider { const EXPIRES_HEADER = 'X-Riak-Meta-Expires'; /** * @var \Riak\Bucket */ private $bucket; /** * Sets the riak bucket instance to use. * * @param \Riak\Bucket $bucket */ public function __construct(Bucket $bucket) { $this->bucket = $bucket; } /** * {@inheritdoc} */ protected function doFetch($id) { try { $response = $this->bucket->get($id); // No objects found if ( ! $response->hasObject()) { return false; } // Check for attempted siblings $object = ($response->hasSiblings()) ? $this->resolveConflict($id, $response->getVClock(), $response->getObjectList()) : $response->getFirstObject(); // Check for expired object if ($this->isExpired($object)) { $this->bucket->delete($object); return false; } return unserialize($object->getContent()); } catch (Exception\RiakException $e) { // Covers: // - Riak\ConnectionException // - Riak\CommunicationException // - Riak\UnexpectedResponseException // - Riak\NotFoundException } return false; } /** * {@inheritdoc} */ protected function doContains($id) { try { // We only need the HEAD, not the entire object $input = new Input\GetInput(); $input->setReturnHead(true); $response = $this->bucket->get($id, $input); // No objects found if ( ! $response->hasObject()) { return false; } $object = $response->getFirstObject(); // Check for expired object if ($this->isExpired($object)) { $this->bucket->delete($object); return false; } return true; } catch (Exception\RiakException $e) { // Do nothing } return false; } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { try { $object = new Object($id); $object->setContent(serialize($data)); if ($lifeTime > 0) { $object->addMetadata(self::EXPIRES_HEADER, (string) (time() + $lifeTime)); } $this->bucket->put($object); return true; } catch (Exception\RiakException $e) { // Do nothing } return false; } /** * {@inheritdoc} */ protected function doDelete($id) { try { $this->bucket->delete($id); return true; } catch (Exception\BadArgumentsException $e) { // Key did not exist on cluster already } catch (Exception\RiakException $e) { // Covers: // - Riak\Exception\ConnectionException // - Riak\Exception\CommunicationException // - Riak\Exception\UnexpectedResponseException } return false; } /** * {@inheritdoc} */ protected function doFlush() { try { $keyList = $this->bucket->getKeyList(); foreach ($keyList as $key) { $this->bucket->delete($key); } return true; } catch (Exception\RiakException $e) { // Do nothing } return false; } /** * {@inheritdoc} */ protected function doGetStats() { // Only exposed through HTTP stats API, not Protocol Buffers API return null; } /** * Check if a given Riak Object have expired. * * @param \Riak\Object $object * * @return boolean */ private function isExpired(Object $object) { $metadataMap = $object->getMetadataMap(); return isset($metadataMap[self::EXPIRES_HEADER]) && $metadataMap[self::EXPIRES_HEADER] < time(); } /** * On-read conflict resolution. Applied approach here is last write wins. * Specific needs may override this method to apply alternate conflict resolutions. * * {@internal Riak does not attempt to resolve a write conflict, and store * it as sibling of conflicted one. By following this approach, it is up to * the next read to resolve the conflict. When this happens, your fetched * object will have a list of siblings (read as a list of objects). * In our specific case, we do not care about the intermediate ones since * they are all the same read from storage, and we do apply a last sibling * (last write) wins logic. * If by any means our resolution generates another conflict, it'll up to * next read to properly solve it.} * * @param string $id * @param string $vClock * @param array $objectList * * @return \Riak\Object */ protected function resolveConflict($id, $vClock, array $objectList) { // Our approach here is last-write wins $winner = $objectList[count($objectList)]; $putInput = new Input\PutInput(); $putInput->setVClock($vClock); $mergedObject = new Object($id); $mergedObject->setContent($winner->getContent()); $this->bucket->put($mergedObject, $putInput); return $mergedObject; } } . */ namespace Doctrine\Common\Cache; class Version { const VERSION = '1.3.0'; } . */ namespace Doctrine\Common\Cache; /** * WinCache cache provider. * * @link www.doctrine-project.org * @since 2.2 * @author Benjamin Eberlei * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author David Abdemoulaie */ class WinCacheCache extends CacheProvider { /** * {@inheritdoc} */ protected function doFetch($id) { return wincache_ucache_get($id); } /** * {@inheritdoc} */ protected function doContains($id) { return wincache_ucache_exists($id); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { return (bool) wincache_ucache_set($id, $data, (int) $lifeTime); } /** * {@inheritdoc} */ protected function doDelete($id) { return wincache_ucache_delete($id); } /** * {@inheritdoc} */ protected function doFlush() { return wincache_ucache_clear(); } /** * {@inheritdoc} */ protected function doGetStats() { $info = wincache_ucache_info(); $meminfo = wincache_ucache_meminfo(); return array( Cache::STATS_HITS => $info['total_hit_count'], Cache::STATS_MISSES => $info['total_miss_count'], Cache::STATS_UPTIME => $info['total_cache_uptime'], Cache::STATS_MEMORY_USAGE => $meminfo['memory_total'], Cache::STATS_MEMORY_AVAILABLE => $meminfo['memory_free'], ); } } . */ namespace Doctrine\Common\Cache; /** * Xcache cache driver. * * @link www.doctrine-project.org * @since 2.0 * @author Benjamin Eberlei * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author David Abdemoulaie */ class XcacheCache extends CacheProvider { /** * {@inheritdoc} */ protected function doFetch($id) { return $this->doContains($id) ? unserialize(xcache_get($id)) : false; } /** * {@inheritdoc} */ protected function doContains($id) { return xcache_isset($id); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { return xcache_set($id, serialize($data), (int) $lifeTime); } /** * {@inheritdoc} */ protected function doDelete($id) { return xcache_unset($id); } /** * {@inheritdoc} */ protected function doFlush() { $this->checkAuthorization(); xcache_clear_cache(XC_TYPE_VAR, 0); return true; } /** * Checks that xcache.admin.enable_auth is Off. * * @return void * * @throws \BadMethodCallException When xcache.admin.enable_auth is On. */ protected function checkAuthorization() { if (ini_get('xcache.admin.enable_auth')) { throw new \BadMethodCallException('To use all features of \Doctrine\Common\Cache\XcacheCache, you must set "xcache.admin.enable_auth" to "Off" in your php.ini.'); } } /** * {@inheritdoc} */ protected function doGetStats() { $this->checkAuthorization(); $info = xcache_info(XC_TYPE_VAR, 0); return array( Cache::STATS_HITS => $info['hits'], Cache::STATS_MISSES => $info['misses'], Cache::STATS_UPTIME => null, Cache::STATS_MEMORY_USAGE => $info['size'], Cache::STATS_MEMORY_AVAILABLE => $info['avail'], ); } } . */ namespace Doctrine\Common\Cache; /** * Zend Data Cache cache driver. * * @link www.doctrine-project.org * @since 2.0 * @author Ralph Schindler * @author Guilherme Blanco */ class ZendDataCache extends CacheProvider { /** * {@inheritdoc} */ protected function doFetch($id) { return zend_shm_cache_fetch($id); } /** * {@inheritdoc} */ protected function doContains($id) { return (false !== zend_shm_cache_fetch($id)); } /** * {@inheritdoc} */ protected function doSave($id, $data, $lifeTime = 0) { return zend_shm_cache_store($id, $data, $lifeTime); } /** * {@inheritdoc} */ protected function doDelete($id) { return zend_shm_cache_delete($id); } /** * {@inheritdoc} */ protected function doFlush() { $namespace = $this->getNamespace(); if (empty($namespace)) { return zend_shm_cache_clear(); } return zend_shm_cache_clear($namespace); } /** * {@inheritdoc} */ protected function doGetStats() { return null; } } decoratedBatch = $decoratedBatch; } /** * Allow decorators to implement custom methods * * @param string $method Missing method name * @param array $args Method arguments * * @return mixed * @codeCoverageIgnore */ public function __call($method, array $args) { return call_user_func_array(array($this->decoratedBatch, $method), $args); } public function add($item) { $this->decoratedBatch->add($item); return $this; } public function flush() { return $this->decoratedBatch->flush(); } public function isEmpty() { return $this->decoratedBatch->isEmpty(); } /** * Trace the decorators associated with the batch * * @return array */ public function getDecorators() { $found = array($this); if (method_exists($this->decoratedBatch, 'getDecorators')) { $found = array_merge($found, $this->decoratedBatch->getDecorators()); } return $found; } } transferStrategy = $transferStrategy; $this->divisionStrategy = $divisionStrategy; $this->queue = new \SplQueue(); $this->queue->setIteratorMode(\SplQueue::IT_MODE_DELETE); $this->dividedBatches = array(); } public function add($item) { $this->queue->enqueue($item); return $this; } public function flush() { $this->createBatches(); $items = array(); foreach ($this->dividedBatches as $batchIndex => $dividedBatch) { while ($dividedBatch->valid()) { $batch = $dividedBatch->current(); $dividedBatch->next(); try { $this->transferStrategy->transfer($batch); $items = array_merge($items, $batch); } catch (\Exception $e) { throw new BatchTransferException($batch, $items, $e, $this->transferStrategy, $this->divisionStrategy); } } // Keep the divided batch down to a minimum in case of a later exception unset($this->dividedBatches[$batchIndex]); } return $items; } public function isEmpty() { return count($this->queue) == 0 && count($this->dividedBatches) == 0; } /** * Create batches for any queued items */ protected function createBatches() { if (count($this->queue)) { if ($batches = $this->divisionStrategy->createBatches($this->queue)) { // Convert arrays into iterators if (is_array($batches)) { $batches = new \ArrayIterator($batches); } $this->dividedBatches[] = $batches; } } } } 'Guzzle\Batch\BatchRequestTransfer', 'command' => 'Guzzle\Batch\BatchCommandTransfer' ); /** * Create a new instance of the BatchBuilder * * @return BatchBuilder */ public static function factory() { return new self(); } /** * Automatically flush the batch when the size of the queue reaches a certain threshold. Adds {@see FlushingBatch}. * * @param $threshold Number of items to allow in the queue before a flush * * @return BatchBuilder */ public function autoFlushAt($threshold) { $this->autoFlush = $threshold; return $this; } /** * Maintain a history of all items that have been transferred using the batch. Adds {@see HistoryBatch}. * * @return BatchBuilder */ public function keepHistory() { $this->history = true; return $this; } /** * Buffer exceptions thrown during transfer so that you can transfer as much as possible, and after a transfer * completes, inspect each exception that was thrown. Enables the {@see ExceptionBufferingBatch} decorator. * * @return BatchBuilder */ public function bufferExceptions() { $this->exceptionBuffering = true; return $this; } /** * Notify a callable each time a batch flush completes. Enables the {@see NotifyingBatch} decorator. * * @param mixed $callable Callable function to notify * * @return BatchBuilder * @throws InvalidArgumentException if the argument is not callable */ public function notify($callable) { $this->afterFlush = $callable; return $this; } /** * Configures the batch to transfer batches of requests. Associates a {@see \Guzzle\Http\BatchRequestTransfer} * object as both the transfer and divisor strategy. * * @param int $batchSize Batch size for each batch of requests * * @return BatchBuilder */ public function transferRequests($batchSize = 50) { $className = self::$mapping['request']; $this->transferStrategy = new $className($batchSize); $this->divisorStrategy = $this->transferStrategy; return $this; } /** * Configures the batch to transfer batches commands. Associates as * {@see \Guzzle\Service\Command\BatchCommandTransfer} as both the transfer and divisor strategy. * * @param int $batchSize Batch size for each batch of commands * * @return BatchBuilder */ public function transferCommands($batchSize = 50) { $className = self::$mapping['command']; $this->transferStrategy = new $className($batchSize); $this->divisorStrategy = $this->transferStrategy; return $this; } /** * Specify the strategy used to divide the queue into an array of batches * * @param BatchDivisorInterface $divisorStrategy Strategy used to divide a batch queue into batches * * @return BatchBuilder */ public function createBatchesWith(BatchDivisorInterface $divisorStrategy) { $this->divisorStrategy = $divisorStrategy; return $this; } /** * Specify the strategy used to transport the items when flush is called * * @param BatchTransferInterface $transferStrategy How items are transferred * * @return BatchBuilder */ public function transferWith(BatchTransferInterface $transferStrategy) { $this->transferStrategy = $transferStrategy; return $this; } /** * Create and return the instantiated batch * * @return BatchInterface * @throws RuntimeException if no transfer strategy has been specified */ public function build() { if (!$this->transferStrategy) { throw new RuntimeException('No transfer strategy has been specified'); } if (!$this->divisorStrategy) { throw new RuntimeException('No divisor strategy has been specified'); } $batch = new Batch($this->transferStrategy, $this->divisorStrategy); if ($this->exceptionBuffering) { $batch = new ExceptionBufferingBatch($batch); } if ($this->afterFlush) { $batch = new NotifyingBatch($batch, $this->afterFlush); } if ($this->autoFlush) { $batch = new FlushingBatch($batch, $this->autoFlush); } if ($this->history) { $batch = new HistoryBatch($batch); } return $batch; } } callable = $callable; $this->context = $context; } public function createBatches(\SplQueue $queue) { return call_user_func($this->callable, $queue, $this->context); } } callable = $callable; $this->context = $context; } public function transfer(array $batch) { return empty($batch) ? null : call_user_func($this->callable, $batch, $this->context); } } batchSize = $batchSize; } /** * Creates batches by grouping commands by their associated client * {@inheritdoc} */ public function createBatches(\SplQueue $queue) { $groups = new \SplObjectStorage(); foreach ($queue as $item) { if (!$item instanceof CommandInterface) { throw new InvalidArgumentException('All items must implement Guzzle\Service\Command\CommandInterface'); } $client = $item->getClient(); if (!$groups->contains($client)) { $groups->attach($client, new \ArrayObject(array($item))); } else { $groups[$client]->append($item); } } $batches = array(); foreach ($groups as $batch) { $batches = array_merge($batches, array_chunk($groups[$batch]->getArrayCopy(), $this->batchSize)); } return $batches; } public function transfer(array $batch) { if (empty($batch)) { return; } // Get the client of the first found command $client = reset($batch)->getClient(); // Keep a list of all commands with invalid clients $invalid = array_filter($batch, function ($command) use ($client) { return $command->getClient() !== $client; }); if (!empty($invalid)) { throw new InconsistentClientTransferException($invalid); } $client->execute($batch); } } batchSize = $batchSize; } /** * Creates batches of requests by grouping requests by their associated curl multi object. * {@inheritdoc} */ public function createBatches(\SplQueue $queue) { // Create batches by client objects $groups = new \SplObjectStorage(); foreach ($queue as $item) { if (!$item instanceof RequestInterface) { throw new InvalidArgumentException('All items must implement Guzzle\Http\Message\RequestInterface'); } $client = $item->getClient(); if (!$groups->contains($client)) { $groups->attach($client, array($item)); } else { $current = $groups[$client]; $current[] = $item; $groups[$client] = $current; } } $batches = array(); foreach ($groups as $batch) { $batches = array_merge($batches, array_chunk($groups[$batch], $this->batchSize)); } return $batches; } public function transfer(array $batch) { if ($batch) { reset($batch)->getClient()->send($batch); } } } size = $size; } /** * Set the size of each batch * * @param int $size Size of each batch * * @return BatchSizeDivisor */ public function setSize($size) { $this->size = $size; return $this; } /** * Get the size of each batch * * @return int */ public function getSize() { return $this->size; } public function createBatches(\SplQueue $queue) { return array_chunk(iterator_to_array($queue, false), $this->size); } } batch = $batch; $this->transferredItems = $transferredItems; $this->transferStrategy = $transferStrategy; $this->divisorStrategy = $divisorStrategy; parent::__construct( 'Exception encountered while transferring batch: ' . $exception->getMessage(), $exception->getCode(), $exception ); } /** * Get the batch that we being sent when the exception occurred * * @return array */ public function getBatch() { return $this->batch; } /** * Get the items transferred at the point in which the exception was encountered * * @return array */ public function getTransferredItems() { return $this->transferredItems; } /** * Get the transfer strategy * * @return TransferStrategy */ public function getTransferStrategy() { return $this->transferStrategy; } /** * Get the divisor strategy * * @return DivisorStrategy */ public function getDivisorStrategy() { return $this->divisorStrategy; } } decoratedBatch->isEmpty()) { try { $transferredItems = $this->decoratedBatch->flush(); } catch (BatchTransferException $e) { $this->exceptions[] = $e; $transferredItems = $e->getTransferredItems(); } $items = array_merge($items, $transferredItems); } return $items; } /** * Get the buffered exceptions * * @return array Array of BatchTransferException objects */ public function getExceptions() { return $this->exceptions; } /** * Clear the buffered exceptions */ public function clearExceptions() { $this->exceptions = array(); } } threshold = $threshold; parent::__construct($decoratedBatch); } /** * Set the auto-flush threshold * * @param int $threshold The auto-flush threshold * * @return FlushingBatch */ public function setThreshold($threshold) { $this->threshold = $threshold; return $this; } /** * Get the auto-flush threshold * * @return int */ public function getThreshold() { return $this->threshold; } public function add($item) { $this->decoratedBatch->add($item); if (++$this->currentTotal >= $this->threshold) { $this->currentTotal = 0; $this->decoratedBatch->flush(); } return $this; } } history[] = $item; $this->decoratedBatch->add($item); return $this; } /** * Get the batch history * * @return array */ public function getHistory() { return $this->history; } /** * Clear the batch history */ public function clearHistory() { $this->history = array(); } } callable = $callable; parent::__construct($decoratedBatch); } public function flush() { $items = $this->decoratedBatch->flush(); call_user_func($this->callable, $items); return $items; } } cache; } } newInstanceArgs($args); } } catch (\Exception $e) { throw new RuntimeException($e->getMessage(), $e->getCode(), $e); } } } callables = $callables; } public function contains($id, array $options = null) { return call_user_func($this->callables['contains'], $id, $options); } public function delete($id, array $options = null) { return call_user_func($this->callables['delete'], $id, $options); } public function fetch($id, array $options = null) { return call_user_func($this->callables['fetch'], $id, $options); } public function save($id, $data, $lifeTime = false, array $options = null) { return call_user_func($this->callables['save'], $id, $data, $lifeTime, $options); } } cache = $cache; } public function contains($id, array $options = null) { return $this->cache->contains($id); } public function delete($id, array $options = null) { return $this->cache->delete($id); } public function fetch($id, array $options = null) { return $this->cache->fetch($id); } public function save($id, $data, $lifeTime = false, array $options = null) { return $this->cache->save($id, $data, $lifeTime); } } cache = $cache; } public function contains($id, array $options = null) { return $this->cache->test($id); } public function delete($id, array $options = null) { return $this->cache->remove($id); } public function fetch($id, array $options = null) { return $this->cache->load($id); } public function save($id, $data, $lifeTime = false, array $options = null) { return $this->cache->save($data, $id, array(), $lifeTime); } } cache = $cache; } public function contains($id, array $options = null) { return $this->cache->hasItem($id); } public function delete($id, array $options = null) { return $this->cache->removeItem($id); } public function fetch($id, array $options = null) { return $this->cache->getItem($id); } public function save($id, $data, $lifeTime = false, array $options = null) { return $this->cache->setItem($id, $data); } } eventDispatcher = $eventDispatcher; return $this; } public function getEventDispatcher() { if (!$this->eventDispatcher) { $this->eventDispatcher = new EventDispatcher(); } return $this->eventDispatcher; } public function dispatch($eventName, array $context = array()) { return $this->getEventDispatcher()->dispatch($eventName, new Event($context)); } public function addSubscriber(EventSubscriberInterface $subscriber) { $this->getEventDispatcher()->addSubscriber($subscriber); return $this; } } data = $data; } /** * Create a new collection from an array, validate the keys, and add default values where missing * * @param array $config Configuration values to apply. * @param array $defaults Default parameters * @param array $required Required parameter names * * @return self * @throws InvalidArgumentException if a parameter is missing */ public static function fromConfig(array $config = array(), array $defaults = array(), array $required = array()) { $data = $config + $defaults; if ($missing = array_diff($required, array_keys($data))) { throw new InvalidArgumentException('Config is missing the following keys: ' . implode(', ', $missing)); } return new self($data); } public function count() { return count($this->data); } public function getIterator() { return new \ArrayIterator($this->data); } public function toArray() { return $this->data; } /** * Removes all key value pairs * * @return Collection */ public function clear() { $this->data = array(); return $this; } /** * Get all or a subset of matching key value pairs * * @param array $keys Pass an array of keys to retrieve only a subset of key value pairs * * @return array Returns an array of all matching key value pairs */ public function getAll(array $keys = null) { return $keys ? array_intersect_key($this->data, array_flip($keys)) : $this->data; } /** * Get a specific key value. * * @param string $key Key to retrieve. * * @return mixed|null Value of the key or NULL */ public function get($key) { return isset($this->data[$key]) ? $this->data[$key] : null; } /** * Set a key value pair * * @param string $key Key to set * @param mixed $value Value to set * * @return Collection Returns a reference to the object */ public function set($key, $value) { $this->data[$key] = $value; return $this; } /** * Add a value to a key. If a key of the same name has already been added, the key value will be converted into an * array and the new value will be pushed to the end of the array. * * @param string $key Key to add * @param mixed $value Value to add to the key * * @return Collection Returns a reference to the object. */ public function add($key, $value) { if (!array_key_exists($key, $this->data)) { $this->data[$key] = $value; } elseif (is_array($this->data[$key])) { $this->data[$key][] = $value; } else { $this->data[$key] = array($this->data[$key], $value); } return $this; } /** * Remove a specific key value pair * * @param string $key A key to remove * * @return Collection */ public function remove($key) { unset($this->data[$key]); return $this; } /** * Get all keys in the collection * * @return array */ public function getKeys() { return array_keys($this->data); } /** * Returns whether or not the specified key is present. * * @param string $key The key for which to check the existence. * * @return bool */ public function hasKey($key) { return array_key_exists($key, $this->data); } /** * Case insensitive search the keys in the collection * * @param string $key Key to search for * * @return bool|string Returns false if not found, otherwise returns the key */ public function keySearch($key) { foreach (array_keys($this->data) as $k) { if (!strcasecmp($k, $key)) { return $k; } } return false; } /** * Checks if any keys contains a certain value * * @param string $value Value to search for * * @return mixed Returns the key if the value was found FALSE if the value was not found. */ public function hasValue($value) { return array_search($value, $this->data); } /** * Replace the data of the object with the value of an array * * @param array $data Associative array of data * * @return Collection Returns a reference to the object */ public function replace(array $data) { $this->data = $data; return $this; } /** * Add and merge in a Collection or array of key value pair data. * * @param Collection|array $data Associative array of key value pair data * * @return Collection Returns a reference to the object. */ public function merge($data) { foreach ($data as $key => $value) { $this->add($key, $value); } return $this; } /** * Over write key value pairs in this collection with all of the data from an array or collection. * * @param array|\Traversable $data Values to override over this config * * @return self */ public function overwriteWith($data) { if (is_array($data)) { $this->data = $data + $this->data; } elseif ($data instanceof Collection) { $this->data = $data->toArray() + $this->data; } else { foreach ($data as $key => $value) { $this->data[$key] = $value; } } return $this; } /** * Returns a Collection containing all the elements of the collection after applying the callback function to each * one. The Closure should accept three parameters: (string) $key, (string) $value, (array) $context and return a * modified value * * @param \Closure $closure Closure to apply * @param array $context Context to pass to the closure * @param bool $static Set to TRUE to use the same class as the return rather than returning a Collection * * @return Collection */ public function map(\Closure $closure, array $context = array(), $static = true) { $collection = $static ? new static() : new self(); foreach ($this as $key => $value) { $collection->add($key, $closure($key, $value, $context)); } return $collection; } /** * Iterates over each key value pair in the collection passing them to the Closure. If the Closure function returns * true, the current value from input is returned into the result Collection. The Closure must accept three * parameters: (string) $key, (string) $value and return Boolean TRUE or FALSE for each value. * * @param \Closure $closure Closure evaluation function * @param bool $static Set to TRUE to use the same class as the return rather than returning a Collection * * @return Collection */ public function filter(\Closure $closure, $static = true) { $collection = ($static) ? new static() : new self(); foreach ($this->data as $key => $value) { if ($closure($key, $value)) { $collection->add($key, $value); } } return $collection; } public function offsetExists($offset) { return isset($this->data[$offset]); } public function offsetGet($offset) { return isset($this->data[$offset]) ? $this->data[$offset] : null; } public function offsetSet($offset, $value) { $this->data[$offset] = $value; } public function offsetUnset($offset) { unset($this->data[$offset]); } /** * Set a value into a nested array key. Keys will be created as needed to set the value. * * @param string $path Path to set * @param mixed $value Value to set at the key * * @return self * @throws RuntimeException when trying to setPath using a nested path that travels through a scalar value */ public function setPath($path, $value) { $current =& $this->data; $queue = explode('/', $path); while (null !== ($key = array_shift($queue))) { if (!is_array($current)) { throw new RuntimeException("Trying to setPath {$path}, but {$key} is set and is not an array"); } elseif (!$queue) { $current[$key] = $value; } elseif (isset($current[$key])) { $current =& $current[$key]; } else { $current[$key] = array(); $current =& $current[$key]; } } return $this; } /** * Gets a value from the collection using an array path (e.g. foo/baz/bar would retrieve bar from two nested arrays) * Allows for wildcard searches which recursively combine matches up to the level at which the wildcard occurs. This * can be useful for accepting any key of a sub-array and combining matching keys from each diverging path. * * @param string $path Path to traverse and retrieve a value from * @param string $separator Character used to add depth to the search * @param mixed $data Optional data to descend into (used when wildcards are encountered) * * @return mixed|null */ public function getPath($path, $separator = '/', $data = null) { if ($data === null) { $data =& $this->data; } $path = is_array($path) ? $path : explode($separator, $path); while (null !== ($part = array_shift($path))) { if (!is_array($data)) { return null; } elseif (isset($data[$part])) { $data =& $data[$part]; } elseif ($part != '*') { return null; } else { // Perform a wildcard search by diverging and merging paths $result = array(); foreach ($data as $value) { if (!$path) { $result = array_merge_recursive($result, (array) $value); } elseif (null !== ($test = $this->getPath($path, $separator, $value))) { $result = array_merge_recursive($result, (array) $test); } } return $result; } } return $data; } /** * Inject configuration settings into an input string * * @param string $input Input to inject * * @return string * @deprecated */ public function inject($input) { Version::warn(__METHOD__ . ' is deprecated'); $replace = array(); foreach ($this->data as $key => $val) { $replace['{' . $key . '}'] = $val; } return strtr($input, $replace); } } context = $context; } public function getIterator() { return new \ArrayIterator($this->context); } public function offsetGet($offset) { return isset($this->context[$offset]) ? $this->context[$offset] : null; } public function offsetSet($offset, $value) { $this->context[$offset] = $value; } public function offsetExists($offset) { return isset($this->context[$offset]); } public function offsetUnset($offset) { unset($this->context[$offset]); } public function toArray() { return $this->context; } } shortMessage = $message; } /** * Set all of the exceptions * * @param array $exceptions Array of exceptions * * @return self */ public function setExceptions(array $exceptions) { $this->exceptions = array(); foreach ($exceptions as $exception) { $this->add($exception); } return $this; } /** * Add exceptions to the collection * * @param ExceptionCollection|\Exception $e Exception to add * * @return ExceptionCollection; */ public function add($e) { $this->exceptions[] = $e; if ($this->message) { $this->message .= "\n"; } $this->message .= $this->getExceptionMessage($e, 0); return $this; } /** * Get the total number of request exceptions * * @return int */ public function count() { return count($this->exceptions); } /** * Allows array-like iteration over the request exceptions * * @return \ArrayIterator */ public function getIterator() { return new \ArrayIterator($this->exceptions); } /** * Get the first exception in the collection * * @return \Exception */ public function getFirst() { return $this->exceptions ? $this->exceptions[0] : null; } private function getExceptionMessage(\Exception $e, $depth = 0) { static $sp = ' '; $prefix = $depth ? str_repeat($sp, $depth) : ''; $message = "{$prefix}(" . get_class($e) . ') ' . $e->getFile() . ' line ' . $e->getLine() . "\n"; if ($e instanceof self) { if ($e->shortMessage) { $message .= "\n{$prefix}{$sp}" . str_replace("\n", "\n{$prefix}{$sp}", $e->shortMessage) . "\n"; } foreach ($e as $ee) { $message .= "\n" . $this->getExceptionMessage($ee, $depth + 1); } } else { $message .= "\n{$prefix}{$sp}" . str_replace("\n", "\n{$prefix}{$sp}", $e->getMessage()) . "\n"; $message .= "\n{$prefix}{$sp}" . str_replace("\n", "\n{$prefix}{$sp}", $e->getTraceAsString()) . "\n"; } return str_replace(getcwd(), '.', $message); } } body = $body; } public function __toString() { return (string) $this->body; } /** * Allow decorators to implement custom methods * * @param string $method Missing method name * @param array $args Method arguments * * @return mixed */ public function __call($method, array $args) { return call_user_func_array(array($this->body, $method), $args); } public function close() { return $this->body->close(); } public function setRewindFunction($callable) { $this->body->setRewindFunction($callable); return $this; } public function rewind() { return $this->body->rewind(); } public function compress($filter = 'zlib.deflate') { return $this->body->compress($filter); } public function uncompress($filter = 'zlib.inflate') { return $this->body->uncompress($filter); } public function getContentLength() { return $this->getSize(); } public function getContentType() { return $this->body->getContentType(); } public function getContentMd5($rawOutput = false, $base64Encode = false) { $hash = Stream::getHash($this, 'md5', $rawOutput); return $hash && $base64Encode ? base64_encode($hash) : $hash; } public function getContentEncoding() { return $this->body->getContentEncoding(); } public function getMetaData($key = null) { return $this->body->getMetaData($key); } public function getStream() { return $this->body->getStream(); } public function setStream($stream, $size = 0) { $this->body->setStream($stream, $size); return $this; } public function detachStream() { $this->body->detachStream(); return $this; } public function getWrapper() { return $this->body->getWrapper(); } public function getWrapperData() { return $this->body->getWrapperData(); } public function getStreamType() { return $this->body->getStreamType(); } public function getUri() { return $this->body->getUri(); } public function getSize() { return $this->body->getSize(); } public function isReadable() { return $this->body->isReadable(); } public function isRepeatable() { return $this->isSeekable() && $this->isReadable(); } public function isWritable() { return $this->body->isWritable(); } public function isConsumed() { return $this->body->isConsumed(); } /** * Alias of isConsumed() * {@inheritdoc} */ public function feof() { return $this->isConsumed(); } public function isLocal() { return $this->body->isLocal(); } public function isSeekable() { return $this->body->isSeekable(); } public function setSize($size) { $this->body->setSize($size); return $this; } public function seek($offset, $whence = SEEK_SET) { return $this->body->seek($offset, $whence); } public function read($length) { return $this->body->read($length); } public function write($string) { return $this->body->write($string); } public function readLine($maxLength = null) { return $this->body->readLine($maxLength); } public function ftell() { return $this->body->ftell(); } public function getCustomData($key) { return $this->body->getCustomData($key); } public function setCustomData($key, $value) { $this->body->setCustomData($key, $value); return $this; } } remoteStream = $body; $this->body = new EntityBody(fopen('php://temp', 'r+')); } /** * Will give the contents of the buffer followed by the exhausted remote stream. * * Warning: Loads the entire stream into memory * * @return string */ public function __toString() { $pos = $this->ftell(); $this->rewind(); $str = ''; while (!$this->isConsumed()) { $str .= $this->read(16384); } $this->seek($pos); return $str; } public function getSize() { return max($this->body->getSize(), $this->remoteStream->getSize()); } /** * {@inheritdoc} * @throws RuntimeException When seeking with SEEK_END or when seeking past the total size of the buffer stream */ public function seek($offset, $whence = SEEK_SET) { if ($whence == SEEK_SET) { $byte = $offset; } elseif ($whence == SEEK_CUR) { $byte = $offset + $this->ftell(); } else { throw new RuntimeException(__CLASS__ . ' supports only SEEK_SET and SEEK_CUR seek operations'); } // You cannot skip ahead past where you've read from the remote stream if ($byte > $this->body->getSize()) { throw new RuntimeException( "Cannot seek to byte {$byte} when the buffered stream only contains {$this->body->getSize()} bytes" ); } return $this->body->seek($byte); } public function rewind() { return $this->seek(0); } /** * Does not support custom rewind functions * * @throws RuntimeException */ public function setRewindFunction($callable) { throw new RuntimeException(__CLASS__ . ' does not support custom stream rewind functions'); } public function read($length) { // Perform a regular read on any previously read data from the buffer $data = $this->body->read($length); $remaining = $length - strlen($data); // More data was requested so read from the remote stream if ($remaining) { // If data was written to the buffer in a position that would have been filled from the remote stream, // then we must skip bytes on the remote stream to emulate overwriting bytes from that position. This // mimics the behavior of other PHP stream wrappers. $remoteData = $this->remoteStream->read($remaining + $this->skipReadBytes); if ($this->skipReadBytes) { $len = strlen($remoteData); $remoteData = substr($remoteData, $this->skipReadBytes); $this->skipReadBytes = max(0, $this->skipReadBytes - $len); } $data .= $remoteData; $this->body->write($remoteData); } return $data; } public function write($string) { // When appending to the end of the currently read stream, you'll want to skip bytes from being read from // the remote stream to emulate other stream wrappers. Basically replacing bytes of data of a fixed length. $overflow = (strlen($string) + $this->ftell()) - $this->remoteStream->ftell(); if ($overflow > 0) { $this->skipReadBytes += $overflow; } return $this->body->write($string); } /** * {@inheritdoc} * @link http://php.net/manual/en/function.fgets.php */ public function readLine($maxLength = null) { $buffer = ''; $size = 0; while (!$this->isConsumed()) { $byte = $this->read(1); $buffer .= $byte; // Break when a new line is found or the max length - 1 is reached if ($byte == PHP_EOL || ++$size == $maxLength - 1) { break; } } return $buffer; } public function isConsumed() { return $this->body->isConsumed() && $this->remoteStream->isConsumed(); } /** * Close both the remote stream and buffer stream */ public function close() { return $this->remoteStream->close() && $this->body->close(); } public function setStream($stream, $size = 0) { $this->remoteStream->setStream($stream, $size); } public function getContentType() { return $this->remoteStream->getContentType(); } public function getContentEncoding() { return $this->remoteStream->getContentEncoding(); } public function getMetaData($key = null) { return $this->remoteStream->getMetaData($key); } public function getStream() { return $this->remoteStream->getStream(); } public function getWrapper() { return $this->remoteStream->getWrapper(); } public function getWrapperData() { return $this->remoteStream->getWrapperData(); } public function getStreamType() { return $this->remoteStream->getStreamType(); } public function getUri() { return $this->remoteStream->getUri(); } /** * Always retrieve custom data from the remote stream * {@inheritdoc} */ public function getCustomData($key) { return $this->remoteStream->getCustomData($key); } /** * Always set custom data on the remote stream * {@inheritdoc} */ public function setCustomData($key, $value) { $this->remoteStream->setCustomData($key, $value); return $this; } } setConfig($config ?: new Collection()); $this->initSsl(); $this->setBaseUrl($baseUrl); $this->defaultHeaders = new Collection(); $this->setRequestFactory(RequestFactory::getInstance()); $this->userAgent = $this->getDefaultUserAgent(); if (!$this->config[self::DISABLE_REDIRECTS]) { $this->addSubscriber(new RedirectPlugin()); } } final public function setConfig($config) { if ($config instanceof Collection) { $this->config = $config; } elseif (is_array($config)) { $this->config = new Collection($config); } else { throw new InvalidArgumentException('Config must be an array or Collection'); } return $this; } final public function getConfig($key = false) { return $key ? $this->config[$key] : $this->config; } /** * Set a default request option on the client that will be used as a default for each request * * @param string $keyOrPath request.options key (e.g. allow_redirects) or path to a nested key (e.g. headers/foo) * @param mixed $value Value to set * * @return $this */ public function setDefaultOption($keyOrPath, $value) { $keyOrPath = self::REQUEST_OPTIONS . '/' . $keyOrPath; $this->config->setPath($keyOrPath, $value); return $this; } /** * Retrieve a default request option from the client * * @param string $keyOrPath request.options key (e.g. allow_redirects) or path to a nested key (e.g. headers/foo) * * @return mixed|null */ public function getDefaultOption($keyOrPath) { $keyOrPath = self::REQUEST_OPTIONS . '/' . $keyOrPath; return $this->config->getPath($keyOrPath); } final public function setSslVerification($certificateAuthority = true, $verifyPeer = true, $verifyHost = 2) { $opts = $this->config[self::CURL_OPTIONS] ?: array(); if ($certificateAuthority === true) { // use bundled CA bundle, set secure defaults $opts[CURLOPT_CAINFO] = __DIR__ . '/Resources/cacert.pem'; $opts[CURLOPT_SSL_VERIFYPEER] = true; $opts[CURLOPT_SSL_VERIFYHOST] = 2; } elseif ($certificateAuthority === false) { unset($opts[CURLOPT_CAINFO]); $opts[CURLOPT_SSL_VERIFYPEER] = false; $opts[CURLOPT_SSL_VERIFYHOST] = 0; } elseif ($verifyPeer !== true && $verifyPeer !== false && $verifyPeer !== 1 && $verifyPeer !== 0) { throw new InvalidArgumentException('verifyPeer must be 1, 0 or boolean'); } elseif ($verifyHost !== 0 && $verifyHost !== 1 && $verifyHost !== 2) { throw new InvalidArgumentException('verifyHost must be 0, 1 or 2'); } else { $opts[CURLOPT_SSL_VERIFYPEER] = $verifyPeer; $opts[CURLOPT_SSL_VERIFYHOST] = $verifyHost; if (is_file($certificateAuthority)) { unset($opts[CURLOPT_CAPATH]); $opts[CURLOPT_CAINFO] = $certificateAuthority; } elseif (is_dir($certificateAuthority)) { unset($opts[CURLOPT_CAINFO]); $opts[CURLOPT_CAPATH] = $certificateAuthority; } else { throw new RuntimeException( 'Invalid option passed to ' . self::SSL_CERT_AUTHORITY . ': ' . $certificateAuthority ); } } $this->config->set(self::CURL_OPTIONS, $opts); return $this; } public function createRequest($method = 'GET', $uri = null, $headers = null, $body = null, array $options = array()) { if (!$uri) { $url = $this->getBaseUrl(); } else { if (!is_array($uri)) { $templateVars = null; } else { list($uri, $templateVars) = $uri; } if (substr($uri, 0, 4) === 'http') { // Use absolute URLs as-is $url = $this->expandTemplate($uri, $templateVars); } else { $url = Url::factory($this->getBaseUrl())->combine($this->expandTemplate($uri, $templateVars)); } } // If default headers are provided, then merge them under any explicitly provided headers for the request if (count($this->defaultHeaders)) { if (!$headers) { $headers = $this->defaultHeaders->toArray(); } elseif (is_array($headers)) { $headers += $this->defaultHeaders->toArray(); } elseif ($headers instanceof Collection) { $headers = $headers->toArray() + $this->defaultHeaders->toArray(); } } return $this->prepareRequest($this->requestFactory->create($method, (string) $url, $headers, $body), $options); } public function getBaseUrl($expand = true) { return $expand ? $this->expandTemplate($this->baseUrl) : $this->baseUrl; } public function setBaseUrl($url) { $this->baseUrl = $url; return $this; } public function setUserAgent($userAgent, $includeDefault = false) { if ($includeDefault) { $userAgent .= ' ' . $this->getDefaultUserAgent(); } $this->userAgent = $userAgent; return $this; } /** * Get the default User-Agent string to use with Guzzle * * @return string */ public function getDefaultUserAgent() { return 'Guzzle/' . Version::VERSION . ' curl/' . CurlVersion::getInstance()->get('version') . ' PHP/' . PHP_VERSION; } public function get($uri = null, $headers = null, $options = array()) { // BC compat: $options can be a string, resource, etc to specify where the response body is downloaded return is_array($options) ? $this->createRequest('GET', $uri, $headers, null, $options) : $this->createRequest('GET', $uri, $headers, $options); } public function head($uri = null, $headers = null, array $options = array()) { return $this->createRequest('HEAD', $uri, $headers, null, $options); } public function delete($uri = null, $headers = null, $body = null, array $options = array()) { return $this->createRequest('DELETE', $uri, $headers, $body, $options); } public function put($uri = null, $headers = null, $body = null, array $options = array()) { return $this->createRequest('PUT', $uri, $headers, $body, $options); } public function patch($uri = null, $headers = null, $body = null, array $options = array()) { return $this->createRequest('PATCH', $uri, $headers, $body, $options); } public function post($uri = null, $headers = null, $postBody = null, array $options = array()) { return $this->createRequest('POST', $uri, $headers, $postBody, $options); } public function options($uri = null, array $options = array()) { return $this->createRequest('OPTIONS', $uri, $options); } public function send($requests) { if (!($requests instanceof RequestInterface)) { return $this->sendMultiple($requests); } try { /** @var $requests RequestInterface */ $this->getCurlMulti()->add($requests)->send(); return $requests->getResponse(); } catch (ExceptionCollection $e) { throw $e->getFirst(); } } /** * Set a curl multi object to be used internally by the client for transferring requests. * * @param CurlMultiInterface $curlMulti Multi object * * @return self */ public function setCurlMulti(CurlMultiInterface $curlMulti) { $this->curlMulti = $curlMulti; return $this; } /** * @return CurlMultiInterface|CurlMultiProxy */ public function getCurlMulti() { if (!$this->curlMulti) { $this->curlMulti = new CurlMultiProxy(); } return $this->curlMulti; } public function setRequestFactory(RequestFactoryInterface $factory) { $this->requestFactory = $factory; return $this; } /** * Set the URI template expander to use with the client * * @param UriTemplateInterface $uriTemplate URI template expander * * @return self */ public function setUriTemplate(UriTemplateInterface $uriTemplate) { $this->uriTemplate = $uriTemplate; return $this; } /** * Copy the cacert.pem file from the phar if it is not in the temp folder and validate the MD5 checksum * * @param bool $md5Check Set to false to not perform the MD5 validation * * @return string Returns the path to the extracted cacert * @throws RuntimeException if the file cannot be copied or there is a MD5 mismatch */ public function preparePharCacert($md5Check = true) { $from = __DIR__ . '/Resources/cacert.pem'; $certFile = sys_get_temp_dir() . '/guzzle-cacert.pem'; if (!file_exists($certFile) && !copy($from, $certFile)) { throw new RuntimeException("Could not copy {$from} to {$certFile}: " . var_export(error_get_last(), true)); } elseif ($md5Check) { $actualMd5 = md5_file($certFile); $expectedMd5 = trim(file_get_contents("{$from}.md5")); if ($actualMd5 != $expectedMd5) { throw new RuntimeException("{$certFile} MD5 mismatch: expected {$expectedMd5} but got {$actualMd5}"); } } return $certFile; } /** * Expand a URI template while merging client config settings into the template variables * * @param string $template Template to expand * @param array $variables Variables to inject * * @return string */ protected function expandTemplate($template, array $variables = null) { $expansionVars = $this->getConfig()->toArray(); if ($variables) { $expansionVars = $variables + $expansionVars; } return $this->getUriTemplate()->expand($template, $expansionVars); } /** * Get the URI template expander used by the client * * @return UriTemplateInterface */ protected function getUriTemplate() { if (!$this->uriTemplate) { $this->uriTemplate = ParserRegistry::getInstance()->getParser('uri_template'); } return $this->uriTemplate; } /** * Send multiple requests in parallel * * @param array $requests Array of RequestInterface objects * * @return array Returns an array of Response objects */ protected function sendMultiple(array $requests) { $curlMulti = $this->getCurlMulti(); foreach ($requests as $request) { $curlMulti->add($request); } $curlMulti->send(); /** @var $request RequestInterface */ $result = array(); foreach ($requests as $request) { $result[] = $request->getResponse(); } return $result; } /** * Prepare a request to be sent from the Client by adding client specific behaviors and properties to the request. * * @param RequestInterface $request Request to prepare for the client * @param array $options Options to apply to the request * * @return RequestInterface */ protected function prepareRequest(RequestInterface $request, array $options = array()) { $request->setClient($this)->setEventDispatcher(clone $this->getEventDispatcher()); if ($curl = $this->config[self::CURL_OPTIONS]) { $request->getCurlOptions()->overwriteWith(CurlHandle::parseCurlConfig($curl)); } if ($params = $this->config[self::REQUEST_PARAMS]) { Version::warn('request.params is deprecated. Use request.options to add default request options.'); $request->getParams()->overwriteWith($params); } if ($this->userAgent && !$request->hasHeader('User-Agent')) { $request->setHeader('User-Agent', $this->userAgent); } if ($defaults = $this->config[self::REQUEST_OPTIONS]) { $this->requestFactory->applyOptions($request, $defaults, RequestFactoryInterface::OPTIONS_AS_DEFAULTS); } if ($options) { $this->requestFactory->applyOptions($request, $options); } $this->dispatch('client.create_request', array('client' => $this, 'request' => $request)); return $request; } /** * Initializes SSL settings */ protected function initSsl() { if ('system' == ($authority = $this->config[self::SSL_CERT_AUTHORITY])) { return; } if ($authority === null) { $authority = true; } if ($authority === true && substr(__FILE__, 0, 7) == 'phar://') { $authority = $this->preparePharCacert(); $that = $this; $this->getEventDispatcher()->addListener('request.before_send', function ($event) use ($authority, $that) { if ($authority == $event['request']->getCurlOptions()->get(CURLOPT_CAINFO)) { $that->preparePharCacert(false); } }); } $this->setSslVerification($authority); } /** * @deprecated */ public function getDefaultHeaders() { Version::warn(__METHOD__ . ' is deprecated. Use the request.options array to retrieve default request options'); return $this->defaultHeaders; } /** * @deprecated */ public function setDefaultHeaders($headers) { Version::warn(__METHOD__ . ' is deprecated. Use the request.options array to specify default request options'); if ($headers instanceof Collection) { $this->defaultHeaders = $headers; } elseif (is_array($headers)) { $this->defaultHeaders = new Collection($headers); } else { throw new InvalidArgumentException('Headers must be an array or Collection'); } return $this; } } getCurlOptions(); $mediator = new RequestMediator($request, $requestCurlOptions->get('emit_io')); $tempContentLength = null; $method = $request->getMethod(); $bodyAsString = $requestCurlOptions->get(self::BODY_AS_STRING); // Prepare url $url = (string)$request->getUrl(); if(($pos = strpos($url, '#')) !== false ){ // strip fragment from url $url = substr($url, 0, $pos); } // Array of default cURL options. $curlOptions = array( CURLOPT_URL => $url, CURLOPT_CONNECTTIMEOUT => 150, CURLOPT_RETURNTRANSFER => false, CURLOPT_HEADER => false, CURLOPT_PORT => $request->getPort(), CURLOPT_HTTPHEADER => array(), CURLOPT_WRITEFUNCTION => array($mediator, 'writeResponseBody'), CURLOPT_HEADERFUNCTION => array($mediator, 'receiveResponseHeader'), CURLOPT_HTTP_VERSION => $request->getProtocolVersion() === '1.0' ? CURL_HTTP_VERSION_1_0 : CURL_HTTP_VERSION_1_1, // Verifies the authenticity of the peer's certificate CURLOPT_SSL_VERIFYPEER => 1, // Certificate must indicate that the server is the server to which you meant to connect CURLOPT_SSL_VERIFYHOST => 2 ); if (defined('CURLOPT_PROTOCOLS')) { // Allow only HTTP and HTTPS protocols $curlOptions[CURLOPT_PROTOCOLS] = CURLPROTO_HTTP | CURLPROTO_HTTPS; } // Add CURLOPT_ENCODING if Accept-Encoding header is provided if ($acceptEncodingHeader = $request->getHeader('Accept-Encoding')) { $curlOptions[CURLOPT_ENCODING] = (string) $acceptEncodingHeader; // Let cURL set the Accept-Encoding header, prevents duplicate values $request->removeHeader('Accept-Encoding'); } // Enable curl debug information if the 'debug' param was set if ($requestCurlOptions->get('debug')) { $curlOptions[CURLOPT_STDERR] = fopen('php://temp', 'r+'); // @codeCoverageIgnoreStart if (false === $curlOptions[CURLOPT_STDERR]) { throw new RuntimeException('Unable to create a stream for CURLOPT_STDERR'); } // @codeCoverageIgnoreEnd $curlOptions[CURLOPT_VERBOSE] = true; } // Specify settings according to the HTTP method if ($method == 'GET') { $curlOptions[CURLOPT_HTTPGET] = true; } elseif ($method == 'HEAD') { $curlOptions[CURLOPT_NOBODY] = true; // HEAD requests do not use a write function unset($curlOptions[CURLOPT_WRITEFUNCTION]); } elseif (!($request instanceof EntityEnclosingRequest)) { $curlOptions[CURLOPT_CUSTOMREQUEST] = $method; } else { $curlOptions[CURLOPT_CUSTOMREQUEST] = $method; // Handle sending raw bodies in a request if ($request->getBody()) { // You can send the body as a string using curl's CURLOPT_POSTFIELDS if ($bodyAsString) { $curlOptions[CURLOPT_POSTFIELDS] = (string) $request->getBody(); // Allow curl to add the Content-Length for us to account for the times when // POST redirects are followed by GET requests if ($tempContentLength = $request->getHeader('Content-Length')) { $tempContentLength = (int) (string) $tempContentLength; } // Remove the curl generated Content-Type header if none was set manually if (!$request->hasHeader('Content-Type')) { $curlOptions[CURLOPT_HTTPHEADER][] = 'Content-Type:'; } } else { $curlOptions[CURLOPT_UPLOAD] = true; // Let cURL handle setting the Content-Length header if ($tempContentLength = $request->getHeader('Content-Length')) { $tempContentLength = (int) (string) $tempContentLength; $curlOptions[CURLOPT_INFILESIZE] = $tempContentLength; } // Add a callback for curl to read data to send with the request only if a body was specified $curlOptions[CURLOPT_READFUNCTION] = array($mediator, 'readRequestBody'); // Attempt to seek to the start of the stream $request->getBody()->seek(0); } } else { // Special handling for POST specific fields and files $postFields = false; if (count($request->getPostFiles())) { $postFields = $request->getPostFields()->useUrlEncoding(false)->urlEncode(); foreach ($request->getPostFiles() as $key => $data) { $prefixKeys = count($data) > 1; foreach ($data as $index => $file) { // Allow multiple files in the same key $fieldKey = $prefixKeys ? "{$key}[{$index}]" : $key; $postFields[$fieldKey] = $file->getCurlValue(); } } } elseif (count($request->getPostFields())) { $postFields = (string) $request->getPostFields()->useUrlEncoding(true); } if ($postFields !== false) { if ($method == 'POST') { unset($curlOptions[CURLOPT_CUSTOMREQUEST]); $curlOptions[CURLOPT_POST] = true; } $curlOptions[CURLOPT_POSTFIELDS] = $postFields; $request->removeHeader('Content-Length'); } } // If the Expect header is not present, prevent curl from adding it if (!$request->hasHeader('Expect')) { $curlOptions[CURLOPT_HTTPHEADER][] = 'Expect:'; } } // If a Content-Length header was specified but we want to allow curl to set one for us if (null !== $tempContentLength) { $request->removeHeader('Content-Length'); } // Set custom cURL options foreach ($requestCurlOptions->toArray() as $key => $value) { if (is_numeric($key)) { $curlOptions[$key] = $value; } } // Do not set an Accept header by default if (!isset($curlOptions[CURLOPT_ENCODING])) { $curlOptions[CURLOPT_HTTPHEADER][] = 'Accept:'; } // Add any custom headers to the request. Empty headers will cause curl to not send the header at all. foreach ($request->getHeaderLines() as $line) { $curlOptions[CURLOPT_HTTPHEADER][] = $line; } // Add the content-length header back if it was temporarily removed if ($tempContentLength) { $request->setHeader('Content-Length', $tempContentLength); } // Apply the options to a new cURL handle. $handle = curl_init(); // Enable the progress function if the 'progress' param was set if ($requestCurlOptions->get('progress')) { // Wrap the function in a function that provides the curl handle to the mediator's progress function // Using this rather than injecting the handle into the mediator prevents a circular reference $curlOptions[CURLOPT_PROGRESSFUNCTION] = function () use ($mediator, $handle) { $args = func_get_args(); $args[] = $handle; // PHP 5.5 pushed the handle onto the start of the args if (is_resource($args[0])) { array_shift($args); } call_user_func_array(array($mediator, 'progress'), $args); }; $curlOptions[CURLOPT_NOPROGRESS] = false; } curl_setopt_array($handle, $curlOptions); return new static($handle, $curlOptions); } /** * Construct a new CurlHandle object that wraps a cURL handle * * @param resource $handle Configured cURL handle resource * @param Collection|array $options Curl options to use with the handle * * @throws InvalidArgumentException */ public function __construct($handle, $options) { if (!is_resource($handle)) { throw new InvalidArgumentException('Invalid handle provided'); } if (is_array($options)) { $this->options = new Collection($options); } elseif ($options instanceof Collection) { $this->options = $options; } else { throw new InvalidArgumentException('Expected array or Collection'); } $this->handle = $handle; } /** * Destructor */ public function __destruct() { $this->close(); } /** * Close the curl handle */ public function close() { if (is_resource($this->handle)) { curl_close($this->handle); } $this->handle = null; } /** * Check if the handle is available and still OK * * @return bool */ public function isAvailable() { return is_resource($this->handle); } /** * Get the last error that occurred on the cURL handle * * @return string */ public function getError() { return $this->isAvailable() ? curl_error($this->handle) : ''; } /** * Get the last error number that occurred on the cURL handle * * @return int */ public function getErrorNo() { if ($this->errorNo) { return $this->errorNo; } return $this->isAvailable() ? curl_errno($this->handle) : CURLE_OK; } /** * Set the curl error number * * @param int $error Error number to set * * @return CurlHandle */ public function setErrorNo($error) { $this->errorNo = $error; return $this; } /** * Get cURL curl_getinfo data * * @param int $option Option to retrieve. Pass null to retrieve all data as an array. * * @return array|mixed */ public function getInfo($option = null) { if (!is_resource($this->handle)) { return null; } if (null !== $option) { return curl_getinfo($this->handle, $option) ?: null; } return curl_getinfo($this->handle) ?: array(); } /** * Get the stderr output * * @param bool $asResource Set to TRUE to get an fopen resource * * @return string|resource|null */ public function getStderr($asResource = false) { $stderr = $this->getOptions()->get(CURLOPT_STDERR); if (!$stderr) { return null; } if ($asResource) { return $stderr; } fseek($stderr, 0); $e = stream_get_contents($stderr); fseek($stderr, 0, SEEK_END); return $e; } /** * Get the URL that this handle is connecting to * * @return Url */ public function getUrl() { return Url::factory($this->options->get(CURLOPT_URL)); } /** * Get the wrapped curl handle * * @return resource|null Returns the cURL handle or null if it was closed */ public function getHandle() { return $this->isAvailable() ? $this->handle : null; } /** * Get the cURL setopt options of the handle. Changing values in the return object will have no effect on the curl * handle after it is created. * * @return Collection */ public function getOptions() { return $this->options; } /** * Update a request based on the log messages of the CurlHandle * * @param RequestInterface $request Request to update */ public function updateRequestFromTransfer(RequestInterface $request) { if (!$request->getResponse()) { return; } // Update the transfer stats of the response $request->getResponse()->setInfo($this->getInfo()); if (!$log = $this->getStderr(true)) { return; } // Parse the cURL stderr output for outgoing requests $headers = ''; fseek($log, 0); while (($line = fgets($log)) !== false) { if ($line && $line[0] == '>') { $headers = substr(trim($line), 2) . "\r\n"; while (($line = fgets($log)) !== false) { if ($line[0] == '*' || $line[0] == '<') { break; } else { $headers .= trim($line) . "\r\n"; } } } } // Add request headers to the request exactly as they were sent if ($headers) { $parsed = ParserRegistry::getInstance()->getParser('message')->parseRequest($headers); if (!empty($parsed['headers'])) { $request->setHeaders(array()); foreach ($parsed['headers'] as $name => $value) { $request->setHeader($name, $value); } } if (!empty($parsed['version'])) { $request->setProtocolVersion($parsed['version']); } } } /** * Parse the config and replace curl.* configurators into the constant based values so it can be used elsewhere * * @param array|Collection $config The configuration we want to parse * * @return array */ public static function parseCurlConfig($config) { $curlOptions = array(); foreach ($config as $key => $value) { if (is_string($key) && defined($key)) { // Convert constants represented as string to constant int values $key = constant($key); } if (is_string($value) && defined($value)) { $value = constant($value); } $curlOptions[$key] = $value; } return $curlOptions; } } array('CURLM_BAD_HANDLE', 'The passed-in handle is not a valid CURLM handle.'), CURLM_BAD_EASY_HANDLE => array('CURLM_BAD_EASY_HANDLE', "An easy handle was not good/valid. It could mean that it isn't an easy handle at all, or possibly that the handle already is in used by this or another multi handle."), CURLM_OUT_OF_MEMORY => array('CURLM_OUT_OF_MEMORY', 'You are doomed.'), CURLM_INTERNAL_ERROR => array('CURLM_INTERNAL_ERROR', 'This can only be returned if libcurl bugs. Please report it to us!') ); public function __construct() { $this->multiHandle = curl_multi_init(); // @codeCoverageIgnoreStart if ($this->multiHandle === false) { throw new CurlException('Unable to create multi handle'); } // @codeCoverageIgnoreEnd $this->reset(); } public function __destruct() { if (is_resource($this->multiHandle)) { curl_multi_close($this->multiHandle); } } public function add(RequestInterface $request) { $this->requests[] = $request; // If requests are currently transferring and this is async, then the // request must be prepared now as the send() method is not called. $this->beforeSend($request); $this->dispatch(self::ADD_REQUEST, array('request' => $request)); return $this; } public function all() { return $this->requests; } public function remove(RequestInterface $request) { $this->removeHandle($request); if (($index = array_search($request, $this->requests, true)) !== false) { $request = $this->requests[$index]; unset($this->requests[$index]); $this->requests = array_values($this->requests); $this->dispatch(self::REMOVE_REQUEST, array('request' => $request)); return true; } return false; } public function reset($hard = false) { // Remove each request if ($this->requests) { foreach ($this->requests as $request) { $this->remove($request); } } $this->handles = new \SplObjectStorage(); $this->requests = $this->resourceHash = $this->exceptions = $this->successful = array(); } public function send() { $this->perform(); $exceptions = $this->exceptions; $successful = $this->successful; $this->reset(); if ($exceptions) { $this->throwMultiException($exceptions, $successful); } } public function count() { return count($this->requests); } /** * Build and throw a MultiTransferException * * @param array $exceptions Exceptions encountered * @param array $successful Successful requests * @throws MultiTransferException */ protected function throwMultiException(array $exceptions, array $successful) { $multiException = new MultiTransferException('Errors during multi transfer'); while ($e = array_shift($exceptions)) { $multiException->addFailedRequestWithException($e['request'], $e['exception']); } // Add successful requests foreach ($successful as $request) { if (!$multiException->containsRequest($request)) { $multiException->addSuccessfulRequest($request); } } throw $multiException; } /** * Prepare for sending * * @param RequestInterface $request Request to prepare * @throws \Exception on error preparing the request */ protected function beforeSend(RequestInterface $request) { try { $state = $request->setState(RequestInterface::STATE_TRANSFER); if ($state == RequestInterface::STATE_TRANSFER) { // Add the request curl handle to the multi handle $handle = $this->createCurlHandle($request)->getHandle(); $this->checkCurlResult(curl_multi_add_handle($this->multiHandle, $handle)); } else { // Requests might decide they don't need to be sent just before transfer (e.g. CachePlugin) $this->remove($request); if ($state == RequestInterface::STATE_COMPLETE) { $this->successful[] = $request; } } } catch (\Exception $e) { // Queue the exception to be thrown when sent $this->removeErroredRequest($request, $e); } } /** * Create a curl handle for a request * * @param RequestInterface $request Request * * @return CurlHandle */ protected function createCurlHandle(RequestInterface $request) { $wrapper = CurlHandle::factory($request); $this->handles[$request] = $wrapper; $this->resourceHash[(int) $wrapper->getHandle()] = $request; return $wrapper; } /** * Get the data from the multi handle */ protected function perform() { $event = new Event(array('curl_multi' => $this)); while ($this->requests) { // Notify each request as polling $blocking = $total = 0; foreach ($this->requests as $request) { ++$total; $event['request'] = $request; $request->getEventDispatcher()->dispatch(self::POLLING_REQUEST, $event); // The blocking variable just has to be non-falsey to block the loop if ($request->getParams()->hasKey(self::BLOCKING)) { ++$blocking; } } if ($blocking == $total) { // Sleep to prevent eating CPU because no requests are actually pending a select call usleep(500); } else { $this->executeHandles(); } } } /** * Execute and select curl handles */ private function executeHandles() { // The first curl_multi_select often times out no matter what, but is usually required for fast transfers $selectTimeout = 0.001; $active = false; do { while (($mrc = curl_multi_exec($this->multiHandle, $active)) == CURLM_CALL_MULTI_PERFORM); $this->checkCurlResult($mrc); $this->processMessages(); if ($active && curl_multi_select($this->multiHandle, $selectTimeout) === -1) { // Perform a usleep if a select returns -1: https://bugs.php.net/bug.php?id=61141 usleep(150); } $selectTimeout = 1; } while ($active); } /** * Process any received curl multi messages */ private function processMessages() { while ($done = curl_multi_info_read($this->multiHandle)) { $request = $this->resourceHash[(int) $done['handle']]; try { $this->processResponse($request, $this->handles[$request], $done); $this->successful[] = $request; } catch (\Exception $e) { $this->removeErroredRequest($request, $e); } } } /** * Remove a request that encountered an exception * * @param RequestInterface $request Request to remove * @param \Exception $e Exception encountered */ protected function removeErroredRequest(RequestInterface $request, \Exception $e = null) { $this->exceptions[] = array('request' => $request, 'exception' => $e); $this->remove($request); $this->dispatch(self::MULTI_EXCEPTION, array('exception' => $e, 'all_exceptions' => $this->exceptions)); } /** * Check for errors and fix headers of a request based on a curl response * * @param RequestInterface $request Request to process * @param CurlHandle $handle Curl handle object * @param array $curl Array returned from curl_multi_info_read * * @throws CurlException on Curl error */ protected function processResponse(RequestInterface $request, CurlHandle $handle, array $curl) { // Set the transfer stats on the response $handle->updateRequestFromTransfer($request); // Check if a cURL exception occurred, and if so, notify things $curlException = $this->isCurlException($request, $handle, $curl); // Always remove completed curl handles. They can be added back again // via events if needed (e.g. ExponentialBackoffPlugin) $this->removeHandle($request); if (!$curlException) { $state = $request->setState(RequestInterface::STATE_COMPLETE, array('handle' => $handle)); // Only remove the request if it wasn't resent as a result of the state change if ($state != RequestInterface::STATE_TRANSFER) { $this->remove($request); } } else { // Set the state of the request to an error $state = $request->setState(RequestInterface::STATE_ERROR, array('exception' => $curlException)); // Allow things to ignore the error if possible if ($state != RequestInterface::STATE_TRANSFER) { $this->remove($request); } // The error was not handled, so fail if ($state == RequestInterface::STATE_ERROR) { /** @var CurlException $curlException */ throw $curlException; } } } /** * Remove a curl handle from the curl multi object * * @param RequestInterface $request Request that owns the handle */ protected function removeHandle(RequestInterface $request) { if (isset($this->handles[$request])) { $handle = $this->handles[$request]; curl_multi_remove_handle($this->multiHandle, $handle->getHandle()); unset($this->handles[$request]); unset($this->resourceHash[(int) $handle->getHandle()]); $handle->close(); } } /** * Check if a cURL transfer resulted in what should be an exception * * @param RequestInterface $request Request to check * @param CurlHandle $handle Curl handle object * @param array $curl Array returned from curl_multi_info_read * * @return CurlException|bool */ private function isCurlException(RequestInterface $request, CurlHandle $handle, array $curl) { if (CURLM_OK == $curl['result'] || CURLM_CALL_MULTI_PERFORM == $curl['result']) { return false; } $handle->setErrorNo($curl['result']); $e = new CurlException(sprintf('[curl] %s: %s [url] %s', $handle->getErrorNo(), $handle->getError(), $handle->getUrl())); $e->setCurlHandle($handle) ->setRequest($request) ->setCurlInfo($handle->getInfo()) ->setError($handle->getError(), $handle->getErrorNo()); return $e; } /** * Throw an exception for a cURL multi response if needed * * @param int $code Curl response code * @throws CurlException */ private function checkCurlResult($code) { if ($code != CURLM_OK && $code != CURLM_CALL_MULTI_PERFORM) { throw new CurlException(isset($this->multiErrors[$code]) ? "cURL error: {$code} ({$this->multiErrors[$code][0]}): cURL message: {$this->multiErrors[$code][1]}" : 'Unexpected cURL error: ' . $code ); } } } maxHandles = $maxHandles; // You can get some weird "Too many open files" errors when sending a large amount of requests in parallel. // These two statements autoload classes before a system runs out of file descriptors so that you can get back // valuable error messages if you run out. class_exists('Guzzle\Http\Message\Response'); class_exists('Guzzle\Http\Exception\CurlException'); } public function add(RequestInterface $request) { $this->queued[] = $request; return $this; } public function all() { $requests = $this->queued; foreach ($this->handles as $handle) { $requests = array_merge($requests, $handle->all()); } return $requests; } public function remove(RequestInterface $request) { foreach ($this->queued as $i => $r) { if ($request === $r) { unset($this->queued[$i]); return true; } } foreach ($this->handles as $handle) { if ($handle->remove($request)) { return true; } } return false; } public function reset($hard = false) { $this->queued = array(); $this->groups = array(); foreach ($this->handles as $handle) { $handle->reset(); } if ($hard) { $this->handles = array(); } return $this; } public function send() { if ($this->queued) { $group = $this->getAvailableHandle(); // Add this handle to a list of handles than is claimed $this->groups[] = $group; while ($request = array_shift($this->queued)) { $group->add($request); } try { $group->send(); array_pop($this->groups); $this->cleanupHandles(); } catch (\Exception $e) { // Remove the group and cleanup if an exception was encountered and no more requests in group if (!$group->count()) { array_pop($this->groups); $this->cleanupHandles(); } throw $e; } } } public function count() { return count($this->all()); } /** * Get an existing available CurlMulti handle or create a new one * * @return CurlMulti */ protected function getAvailableHandle() { // Grab a handle that is not claimed foreach ($this->handles as $h) { if (!in_array($h, $this->groups, true)) { return $h; } } // All are claimed, so create one $handle = new CurlMulti(); $handle->setEventDispatcher($this->getEventDispatcher()); $this->handles[] = $handle; return $handle; } /** * Trims down unused CurlMulti handles to limit the number of open connections */ protected function cleanupHandles() { if ($diff = max(0, count($this->handles) - $this->maxHandles)) { for ($i = count($this->handles) - 1; $i > 0 && $diff > 0; $i--) { if (!count($this->handles[$i])) { unset($this->handles[$i]); $diff--; } } $this->handles = array_values($this->handles); } } } version) { $this->version = curl_version(); } return $this->version; } /** * Get a specific type of curl information * * @param string $type Version information to retrieve. This value is one of: * - version_number: cURL 24 bit version number * - version: cURL version number, as a string * - ssl_version_number: OpenSSL 24 bit version number * - ssl_version: OpenSSL version number, as a string * - libz_version: zlib version number, as a string * - host: Information about the host where cURL was built * - features: A bitmask of the CURL_VERSION_XXX constants * - protocols: An array of protocols names supported by cURL * * @return string|float|bool if the $type is found, and false if not found */ public function get($type) { $version = $this->getAll(); return isset($version[$type]) ? $version[$type] : false; } } request = $request; $this->emitIo = $emitIo; } /** * Receive a response header from curl * * @param resource $curl Curl handle * @param string $header Received header * * @return int */ public function receiveResponseHeader($curl, $header) { static $normalize = array("\r", "\n"); $length = strlen($header); $header = str_replace($normalize, '', $header); if (strpos($header, 'HTTP/') === 0) { $startLine = explode(' ', $header, 3); $code = $startLine[1]; $status = isset($startLine[2]) ? $startLine[2] : ''; // Only download the body of the response to the specified response // body when a successful response is received. if ($code >= 200 && $code < 300) { $body = $this->request->getResponseBody(); } else { $body = EntityBody::factory(); } $response = new Response($code, null, $body); $response->setStatus($code, $status); $this->request->startResponse($response); $this->request->dispatch('request.receive.status_line', array( 'request' => $this, 'line' => $header, 'status_code' => $code, 'reason_phrase' => $status )); } elseif ($pos = strpos($header, ':')) { $this->request->getResponse()->addHeader( trim(substr($header, 0, $pos)), trim(substr($header, $pos + 1)) ); } return $length; } /** * Received a progress notification * * @param int $downloadSize Total download size * @param int $downloaded Amount of bytes downloaded * @param int $uploadSize Total upload size * @param int $uploaded Amount of bytes uploaded * @param resource $handle CurlHandle object */ public function progress($downloadSize, $downloaded, $uploadSize, $uploaded, $handle = null) { $this->request->dispatch('curl.callback.progress', array( 'request' => $this->request, 'handle' => $handle, 'download_size' => $downloadSize, 'downloaded' => $downloaded, 'upload_size' => $uploadSize, 'uploaded' => $uploaded )); } /** * Write data to the response body of a request * * @param resource $curl Curl handle * @param string $write Data that was received * * @return int */ public function writeResponseBody($curl, $write) { if ($this->emitIo) { $this->request->dispatch('curl.callback.write', array( 'request' => $this->request, 'write' => $write )); } if ($response = $this->request->getResponse()) { return $response->getBody()->write($write); } else { // Unexpected data received before response headers - abort transfer return 0; } } /** * Read data from the request body and send it to curl * * @param resource $ch Curl handle * @param resource $fd File descriptor * @param int $length Amount of data to read * * @return string */ public function readRequestBody($ch, $fd, $length) { if (!($body = $this->request->getBody())) { return ''; } $read = (string) $body->read($length); if ($this->emitIo) { $this->request->dispatch('curl.callback.read', array('request' => $this->request, 'read' => $read)); } return $read; } } rewindFunction = $callable; return $this; } public function rewind() { return $this->rewindFunction ? call_user_func($this->rewindFunction, $this) : parent::rewind(); } /** * Create a new EntityBody from a string * * @param string $string String of data * * @return EntityBody */ public static function fromString($string) { $stream = fopen('php://temp', 'r+'); if ($string !== '') { fwrite($stream, $string); rewind($stream); } return new static($stream); } public function compress($filter = 'zlib.deflate') { $result = $this->handleCompression($filter); $this->contentEncoding = $result ? $filter : false; return $result; } public function uncompress($filter = 'zlib.inflate') { $offsetStart = 0; // When inflating gzipped data, the first 10 bytes must be stripped // if a gzip header is present if ($filter == 'zlib.inflate') { // @codeCoverageIgnoreStart if (!$this->isReadable() || ($this->isConsumed() && !$this->isSeekable())) { return false; } // @codeCoverageIgnoreEnd if (stream_get_contents($this->stream, 3, 0) === "\x1f\x8b\x08") { $offsetStart = 10; } } $this->contentEncoding = false; return $this->handleCompression($filter, $offsetStart); } public function getContentLength() { return $this->getSize(); } public function getContentType() { return $this->getUri() ? Mimetypes::getInstance()->fromFilename($this->getUri()) : null; } public function getContentMd5($rawOutput = false, $base64Encode = false) { if ($hash = self::getHash($this, 'md5', $rawOutput)) { return $hash && $base64Encode ? base64_encode($hash) : $hash; } else { return false; } } /** * Calculate the MD5 hash of an entity body * * @param EntityBodyInterface $body Entity body to calculate the hash for * @param bool $rawOutput Whether or not to use raw output * @param bool $base64Encode Whether or not to base64 encode raw output (only if raw output is true) * * @return bool|string Returns an MD5 string on success or FALSE on failure * @deprecated This will be deprecated soon * @codeCoverageIgnore */ public static function calculateMd5(EntityBodyInterface $body, $rawOutput = false, $base64Encode = false) { Version::warn(__CLASS__ . ' is deprecated. Use getContentMd5()'); return $body->getContentMd5($rawOutput, $base64Encode); } public function setStreamFilterContentEncoding($streamFilterContentEncoding) { $this->contentEncoding = $streamFilterContentEncoding; return $this; } public function getContentEncoding() { return strtr($this->contentEncoding, array( 'zlib.deflate' => 'gzip', 'bzip2.compress' => 'compress' )) ?: false; } protected function handleCompression($filter, $offsetStart = 0) { // @codeCoverageIgnoreStart if (!$this->isReadable() || ($this->isConsumed() && !$this->isSeekable())) { return false; } // @codeCoverageIgnoreEnd $handle = fopen('php://temp', 'r+'); $filter = @stream_filter_append($handle, $filter, STREAM_FILTER_WRITE); if (!$filter) { return false; } // Seek to the offset start if possible $this->seek($offsetStart); while ($data = fread($this->stream, 8096)) { fwrite($handle, $data); } fclose($this->stream); $this->stream = $handle; stream_filter_remove($filter); $stat = fstat($this->stream); $this->size = $stat['size']; $this->rebuildCache(); $this->seek(0); // Remove any existing rewind function as the underlying stream has been replaced $this->rewindFunction = null; return true; } } isClientError()) { $label = 'Client error response'; $class = __NAMESPACE__ . '\\ClientErrorResponseException'; } elseif ($response->isServerError()) { $label = 'Server error response'; $class = __NAMESPACE__ . '\\ServerErrorResponseException'; } else { $label = 'Unsuccessful response'; $class = __CLASS__; } $message = $label . PHP_EOL . implode(PHP_EOL, array( '[status code] ' . $response->getStatusCode(), '[reason phrase] ' . $response->getReasonPhrase(), '[url] ' . $request->getUrl(), )); $e = new $class($message); $e->setResponse($response); $e->setRequest($request); return $e; } /** * Set the response that caused the exception * * @param Response $response Response to set */ public function setResponse(Response $response) { $this->response = $response; } /** * Get the response that caused the exception * * @return Response */ public function getResponse() { return $this->response; } } curlError = $error; $this->curlErrorNo = $number; return $this; } /** * Set the associated curl handle * * @param CurlHandle $handle Curl handle * * @return self */ public function setCurlHandle(CurlHandle $handle) { $this->handle = $handle; return $this; } /** * Get the associated cURL handle * * @return CurlHandle|null */ public function getCurlHandle() { return $this->handle; } /** * Get the associated cURL error message * * @return string|null */ public function getError() { return $this->curlError; } /** * Get the associated cURL error number * * @return int|null */ public function getErrorNo() { return $this->curlErrorNo; } /** * Returns curl information about the transfer * * @return array */ public function getCurlInfo() { return $this->curlInfo; } /** * Set curl transfer information * * @param array $info Array of curl transfer information * * @return self * @link http://php.net/manual/en/function.curl-getinfo.php */ public function setCurlInfo(array $info) { $this->curlInfo = $info; return $this; } } successfulRequests, $this->failedRequests); } /** * Add to the array of successful requests * * @param RequestInterface $request Successful request * * @return self */ public function addSuccessfulRequest(RequestInterface $request) { $this->successfulRequests[] = $request; return $this; } /** * Add to the array of failed requests * * @param RequestInterface $request Failed request * * @return self */ public function addFailedRequest(RequestInterface $request) { $this->failedRequests[] = $request; return $this; } /** * Add to the array of failed requests and associate with exceptions * * @param RequestInterface $request Failed request * @param \Exception $exception Exception to add and associate with * * @return self */ public function addFailedRequestWithException(RequestInterface $request, \Exception $exception) { $this->add($exception) ->addFailedRequest($request) ->exceptionForRequest[spl_object_hash($request)] = $exception; return $this; } /** * Get the Exception that caused the given $request to fail * * @param RequestInterface $request Failed command * * @return \Exception|null */ public function getExceptionForFailedRequest(RequestInterface $request) { $oid = spl_object_hash($request); return isset($this->exceptionForRequest[$oid]) ? $this->exceptionForRequest[$oid] : null; } /** * Set all of the successful requests * * @param array Array of requests * * @return self */ public function setSuccessfulRequests(array $requests) { $this->successfulRequests = $requests; return $this; } /** * Set all of the failed requests * * @param array Array of requests * * @return self */ public function setFailedRequests(array $requests) { $this->failedRequests = $requests; return $this; } /** * Get an array of successful requests sent in the multi transfer * * @return array */ public function getSuccessfulRequests() { return $this->successfulRequests; } /** * Get an array of failed requests sent in the multi transfer * * @return array */ public function getFailedRequests() { return $this->failedRequests; } /** * Check if the exception object contains a request * * @param RequestInterface $request Request to check * * @return bool */ public function containsRequest(RequestInterface $request) { return in_array($request, $this->failedRequests, true) || in_array($request, $this->successfulRequests, true); } } request = $request; return $this; } /** * Get the request that caused the exception * * @return RequestInterface */ public function getRequest() { return $this->request; } } eventDispatcher = $eventDispatcher; return $this; } public function getEventDispatcher() { if (!$this->eventDispatcher) { $this->eventDispatcher = new EventDispatcher(); } return $this->eventDispatcher; } public function dispatch($eventName, array $context = array()) { return $this->getEventDispatcher()->dispatch($eventName, new Event($context)); } /** * {@inheritdoc} * @codeCoverageIgnore */ public function addSubscriber(EventSubscriberInterface $subscriber) { $this->getEventDispatcher()->addSubscriber($subscriber); return $this; } public function read($length) { $event = array( 'body' => $this, 'length' => $length, 'read' => $this->body->read($length) ); $this->dispatch('body.read', $event); return $event['read']; } public function write($string) { $event = array( 'body' => $this, 'write' => $string, 'result' => $this->body->write($string) ); $this->dispatch('body.write', $event); return $event['result']; } } params = new Collection(); $this->headerFactory = new HeaderFactory(); $this->headers = new HeaderCollection(); } /** * Set the header factory to use to create headers * * @param HeaderFactoryInterface $factory * * @return self */ public function setHeaderFactory(HeaderFactoryInterface $factory) { $this->headerFactory = $factory; return $this; } public function getParams() { return $this->params; } public function addHeader($header, $value) { if (isset($this->headers[$header])) { $this->headers[$header]->add($value); } elseif ($value instanceof HeaderInterface) { $this->headers[$header] = $value; } else { $this->headers[$header] = $this->headerFactory->createHeader($header, $value); } return $this; } public function addHeaders(array $headers) { foreach ($headers as $key => $value) { $this->addHeader($key, $value); } return $this; } public function getHeader($header) { return $this->headers[$header]; } public function getHeaders() { return $this->headers; } public function getHeaderLines() { $headers = array(); foreach ($this->headers as $value) { $headers[] = $value->getName() . ': ' . $value; } return $headers; } public function setHeader($header, $value) { unset($this->headers[$header]); $this->addHeader($header, $value); return $this; } public function setHeaders(array $headers) { $this->headers->clear(); foreach ($headers as $key => $value) { $this->addHeader($key, $value); } return $this; } public function hasHeader($header) { return isset($this->headers[$header]); } public function removeHeader($header) { unset($this->headers[$header]); return $this; } /** * @deprecated Use $message->getHeader()->parseParams() * @codeCoverageIgnore */ public function getTokenizedHeader($header, $token = ';') { Version::warn(__METHOD__ . ' is deprecated. Use $message->getHeader()->parseParams()'); if ($this->hasHeader($header)) { $data = new Collection(); foreach ($this->getHeader($header)->parseParams() as $values) { foreach ($values as $key => $value) { if ($value === '') { $data->set($data->count(), $key); } else { $data->add($key, $value); } } } return $data; } } /** * @deprecated * @codeCoverageIgnore */ public function setTokenizedHeader($header, $data, $token = ';') { Version::warn(__METHOD__ . ' is deprecated.'); return $this; } /** * @deprecated * @codeCoverageIgnore */ public function getCacheControlDirective($directive) { Version::warn(__METHOD__ . ' is deprecated. Use $message->getHeader(\'Cache-Control\')->getDirective()'); if (!($header = $this->getHeader('Cache-Control'))) { return null; } return $header->getDirective($directive); } /** * @deprecated * @codeCoverageIgnore */ public function hasCacheControlDirective($directive) { Version::warn(__METHOD__ . ' is deprecated. Use $message->getHeader(\'Cache-Control\')->hasDirective()'); if ($header = $this->getHeader('Cache-Control')) { return $header->hasDirective($directive); } else { return false; } } /** * @deprecated * @codeCoverageIgnore */ public function addCacheControlDirective($directive, $value = true) { Version::warn(__METHOD__ . ' is deprecated. Use $message->getHeader(\'Cache-Control\')->addDirective()'); if (!($header = $this->getHeader('Cache-Control'))) { $this->addHeader('Cache-Control', ''); $header = $this->getHeader('Cache-Control'); } $header->addDirective($directive, $value); return $this; } /** * @deprecated * @codeCoverageIgnore */ public function removeCacheControlDirective($directive) { Version::warn(__METHOD__ . ' is deprecated. Use $message->getHeader(\'Cache-Control\')->removeDirective()'); if ($header = $this->getHeader('Cache-Control')) { $header->removeDirective($directive); } return $this; } } postFields = new QueryString(); parent::__construct($method, $url, $headers); } /** * @return string */ public function __toString() { // Only attempt to include the POST data if it's only fields if (count($this->postFields) && empty($this->postFiles)) { return parent::__toString() . (string) $this->postFields; } return parent::__toString() . $this->body; } public function setState($state, array $context = array()) { parent::setState($state, $context); if ($state == self::STATE_TRANSFER && !$this->body && !count($this->postFields) && !count($this->postFiles)) { $this->setHeader('Content-Length', 0)->removeHeader('Transfer-Encoding'); } return $this->state; } public function setBody($body, $contentType = null) { $this->body = EntityBody::factory($body); // Auto detect the Content-Type from the path of the request if possible if ($contentType === null && !$this->hasHeader('Content-Type')) { $contentType = $this->body->getContentType(); } if ($contentType) { $this->setHeader('Content-Type', $contentType); } // Always add the Expect 100-Continue header if the body cannot be rewound. This helps with redirects. if (!$this->body->isSeekable() && $this->expectCutoff !== false) { $this->setHeader('Expect', '100-Continue'); } // Set the Content-Length header if it can be determined $size = $this->body->getContentLength(); if ($size !== null && $size !== false) { $this->setHeader('Content-Length', $size); if ($size > $this->expectCutoff) { $this->setHeader('Expect', '100-Continue'); } } elseif (!$this->hasHeader('Content-Length')) { if ('1.1' == $this->protocolVersion) { $this->setHeader('Transfer-Encoding', 'chunked'); } else { throw new RequestException( 'Cannot determine Content-Length and cannot use chunked Transfer-Encoding when using HTTP/1.0' ); } } return $this; } public function getBody() { return $this->body; } /** * Set the size that the entity body of the request must exceed before adding the Expect: 100-Continue header. * * @param int|bool $size Cutoff in bytes. Set to false to never send the expect header (even with non-seekable data) * * @return self */ public function setExpectHeaderCutoff($size) { $this->expectCutoff = $size; if ($size === false || !$this->body) { $this->removeHeader('Expect'); } elseif ($this->body && $this->body->getSize() && $this->body->getSize() > $size) { $this->setHeader('Expect', '100-Continue'); } return $this; } public function configureRedirects($strict = false, $maxRedirects = 5) { $this->getParams()->set(RedirectPlugin::STRICT_REDIRECTS, $strict); if ($maxRedirects == 0) { $this->getParams()->set(RedirectPlugin::DISABLE, true); } else { $this->getParams()->set(RedirectPlugin::MAX_REDIRECTS, $maxRedirects); } return $this; } public function getPostField($field) { return $this->postFields->get($field); } public function getPostFields() { return $this->postFields; } public function setPostField($key, $value) { $this->postFields->set($key, $value); $this->processPostFields(); return $this; } public function addPostFields($fields) { $this->postFields->merge($fields); $this->processPostFields(); return $this; } public function removePostField($field) { $this->postFields->remove($field); $this->processPostFields(); return $this; } public function getPostFiles() { return $this->postFiles; } public function getPostFile($fieldName) { return isset($this->postFiles[$fieldName]) ? $this->postFiles[$fieldName] : null; } public function removePostFile($fieldName) { unset($this->postFiles[$fieldName]); $this->processPostFields(); return $this; } public function addPostFile($field, $filename = null, $contentType = null, $postname = null) { $data = null; if ($field instanceof PostFileInterface) { $data = $field; } elseif (is_array($filename)) { // Allow multiple values to be set in a single key foreach ($filename as $file) { $this->addPostFile($field, $file, $contentType); } return $this; } elseif (!is_string($filename)) { throw new RequestException('The path to a file must be a string'); } elseif (!empty($filename)) { // Adding an empty file will cause cURL to error out $data = new PostFile($field, $filename, $contentType, $postname); } if ($data) { if (!isset($this->postFiles[$data->getFieldName()])) { $this->postFiles[$data->getFieldName()] = array($data); } else { $this->postFiles[$data->getFieldName()][] = $data; } $this->processPostFields(); } return $this; } public function addPostFiles(array $files) { foreach ($files as $key => $file) { if ($file instanceof PostFileInterface) { $this->addPostFile($file, null, null, false); } elseif (is_string($file)) { // Convert non-associative array keys into 'file' if (is_numeric($key)) { $key = 'file'; } $this->addPostFile($key, $file, null, false); } else { throw new RequestException('File must be a string or instance of PostFileInterface'); } } return $this; } /** * Determine what type of request should be sent based on post fields */ protected function processPostFields() { if (!$this->postFiles) { $this->removeHeader('Expect')->setHeader('Content-Type', self::URL_ENCODED); } else { $this->setHeader('Content-Type', self::MULTIPART); if ($this->expectCutoff !== false) { $this->setHeader('Expect', '100-Continue'); } } } } filenames where filename can be a string or PostFileInterface * * @return self */ public function addPostFiles(array $files); /** * Configure how redirects are handled for the request * * @param bool $strict Set to true to follow strict RFC compliance when redirecting POST requests. Most * browsers with follow a 301-302 redirect for a POST request with a GET request. This is * the default behavior of Guzzle. Enable strict redirects to redirect these responses * with a POST rather than a GET request. * @param int $maxRedirects Specify the maximum number of allowed redirects. Set to 0 to disable redirects. * * @return self */ public function configureRedirects($strict = false, $maxRedirects = 5); } directives = null; } public function removeValue($searchValue) { parent::removeValue($searchValue); $this->directives = null; } /** * Check if a specific cache control directive exists * * @param string $param Directive to retrieve * * @return bool */ public function hasDirective($param) { $directives = $this->getDirectives(); return isset($directives[$param]); } /** * Get a specific cache control directive * * @param string $param Directive to retrieve * * @return string|bool|null */ public function getDirective($param) { $directives = $this->getDirectives(); return isset($directives[$param]) ? $directives[$param] : null; } /** * Add a cache control directive * * @param string $param Directive to add * @param string $value Value to set * * @return self */ public function addDirective($param, $value) { $directives = $this->getDirectives(); $directives[$param] = $value; $this->updateFromDirectives($directives); return $this; } /** * Remove a cache control directive by name * * @param string $param Directive to remove * * @return self */ public function removeDirective($param) { $directives = $this->getDirectives(); unset($directives[$param]); $this->updateFromDirectives($directives); return $this; } /** * Get an associative array of cache control directives * * @return array */ public function getDirectives() { if ($this->directives === null) { $this->directives = array(); foreach ($this->parseParams() as $collection) { foreach ($collection as $key => $value) { $this->directives[$key] = $value === '' ? true : $value; } } } return $this->directives; } /** * Updates the header value based on the parsed directives * * @param array $directives Array of cache control directives */ protected function updateFromDirectives(array $directives) { $this->directives = $directives; $this->values = array(); foreach ($directives as $key => $value) { $this->values[] = $value === true ? $key : "{$key}={$value}"; } } } headers = $headers; } public function __clone() { foreach ($this->headers as &$header) { $header = clone $header; } } /** * Clears the header collection */ public function clear() { $this->headers = array(); } /** * Set a header on the collection * * @param HeaderInterface $header Header to add * * @return self */ public function add(HeaderInterface $header) { $this->headers[strtolower($header->getName())] = $header; return $this; } /** * Get an array of header objects * * @return array */ public function getAll() { return $this->headers; } /** * Alias of offsetGet */ public function get($key) { return $this->offsetGet($key); } public function count() { return count($this->headers); } public function offsetExists($offset) { return isset($this->headers[strtolower($offset)]); } public function offsetGet($offset) { $l = strtolower($offset); return isset($this->headers[$l]) ? $this->headers[$l] : null; } public function offsetSet($offset, $value) { $this->add($value); } public function offsetUnset($offset) { unset($this->headers[strtolower($offset)]); } public function getIterator() { return new \ArrayIterator($this->headers); } public function toArray() { $result = array(); foreach ($this->headers as $header) { $result[$header->getName()] = $header->toArray(); } return $result; } } 'Guzzle\Http\Message\Header\CacheControl', 'link' => 'Guzzle\Http\Message\Header\Link', ); public function createHeader($header, $value = null) { $lowercase = strtolower($header); return isset($this->mapping[$lowercase]) ? new $this->mapping[$lowercase]($header, $value) : new Header($header, $value); } } ", "rel=\"{$rel}\""); foreach ($params as $k => $v) { $values[] = "{$k}=\"{$v}\""; } return $this->add(implode('; ', $values)); } /** * Check if a specific link exists for a given rel attribute * * @param string $rel rel value * * @return bool */ public function hasLink($rel) { return $this->getLink($rel) !== null; } /** * Get a specific link for a given rel attribute * * @param string $rel Rel value * * @return array|null */ public function getLink($rel) { foreach ($this->getLinks() as $link) { if (isset($link['rel']) && $link['rel'] == $rel) { return $link; } } return null; } /** * Get an associative array of links * * For example: * Link: ; rel=front; type="image/jpeg", ; rel=back; type="image/jpeg" * * * var_export($response->getLinks()); * array( * array( * 'url' => 'http:/.../front.jpeg', * 'rel' => 'back', * 'type' => 'image/jpeg', * ) * ) * * * @return array */ public function getLinks() { $links = $this->parseParams(); foreach ($links as &$link) { $key = key($link); unset($link[$key]); $link['url'] = trim($key, '<> '); } return $links; } } header = trim($header); $this->glue = $glue; foreach ((array) $values as $value) { foreach ((array) $value as $v) { $this->values[] = $v; } } } public function __toString() { return implode($this->glue . ' ', $this->toArray()); } public function add($value) { $this->values[] = $value; return $this; } public function getName() { return $this->header; } public function setName($name) { $this->header = $name; return $this; } public function setGlue($glue) { $this->glue = $glue; return $this; } public function getGlue() { return $this->glue; } /** * Normalize the header to be a single header with an array of values. * * If any values of the header contains the glue string value (e.g. ","), then the value will be exploded into * multiple entries in the header. * * @return self */ public function normalize() { $values = $this->toArray(); for ($i = 0, $total = count($values); $i < $total; $i++) { if (strpos($values[$i], $this->glue) !== false) { // Explode on glue when the glue is not inside of a comma foreach (preg_split('/' . preg_quote($this->glue) . '(?=([^"]*"[^"]*")*[^"]*$)/', $values[$i]) as $v) { $values[] = trim($v); } unset($values[$i]); } } $this->values = array_values($values); return $this; } public function hasValue($searchValue) { return in_array($searchValue, $this->toArray()); } public function removeValue($searchValue) { $this->values = array_values(array_filter($this->values, function ($value) use ($searchValue) { return $value != $searchValue; })); return $this; } public function toArray() { return $this->values; } public function count() { return count($this->toArray()); } public function getIterator() { return new \ArrayIterator($this->toArray()); } public function parseParams() { $params = $matches = array(); $callback = array($this, 'trimHeader'); // Normalize the header into a single array and iterate over all values foreach ($this->normalize()->toArray() as $val) { $part = array(); foreach (preg_split('/;(?=([^"]*"[^"]*")*[^"]*$)/', $val) as $kvp) { if (!preg_match_all('/<[^>]+>|[^=]+/', $kvp, $matches)) { continue; } $pieces = array_map($callback, $matches[0]); $part[$pieces[0]] = isset($pieces[1]) ? $pieces[1] : ''; } if ($part) { $params[] = $part; } } return $params; } /** * @deprecated * @codeCoverageIgnore */ public function hasExactHeader($header) { Version::warn(__METHOD__ . ' is deprecated'); return $this->header == $header; } /** * @deprecated * @codeCoverageIgnore */ public function raw() { Version::warn(__METHOD__ . ' is deprecated. Use toArray()'); return $this->toArray(); } /** * Trim a header by removing excess spaces and wrapping quotes * * @param $str * * @return string */ protected function trimHeader($str) { static $trimmed = "\"' \n\t"; return trim($str, $trimmed); } } fieldName = $fieldName; $this->setFilename($filename); $this->postname = $postname ? $postname : basename($filename); $this->contentType = $contentType ?: $this->guessContentType(); } public function setFieldName($name) { $this->fieldName = $name; return $this; } public function getFieldName() { return $this->fieldName; } public function setFilename($filename) { // Remove leading @ symbol if (strpos($filename, '@') === 0) { $filename = substr($filename, 1); } if (!is_readable($filename)) { throw new InvalidArgumentException("Unable to open {$filename} for reading"); } $this->filename = $filename; return $this; } public function setPostname($postname) { $this->postname = $postname; return $this; } public function getFilename() { return $this->filename; } public function getPostname() { return $this->postname; } public function setContentType($type) { $this->contentType = $type; return $this; } public function getContentType() { return $this->contentType; } public function getCurlValue() { // PHP 5.5 introduced a CurlFile object that deprecates the old @filename syntax // See: https://wiki.php.net/rfc/curl-file-upload if (function_exists('curl_file_create')) { return curl_file_create($this->filename, $this->contentType, $this->postname); } // Use the old style if using an older version of PHP $value = "@{$this->filename};filename=" . $this->postname; if ($this->contentType) { $value .= ';type=' . $this->contentType; } return $value; } /** * @deprecated * @codeCoverageIgnore */ public function getCurlString() { Version::warn(__METHOD__ . ' is deprecated. Use getCurlValue()'); return $this->getCurlValue(); } /** * Determine the Content-Type of the file */ protected function guessContentType() { return Mimetypes::getInstance()->fromFilename($this->filename) ?: 'application/octet-stream'; } } method = strtoupper($method); $this->curlOptions = new Collection(); $this->setUrl($url); if ($headers) { // Special handling for multi-value headers foreach ($headers as $key => $value) { // Deal with collisions with Host and Authorization if ($key == 'host' || $key == 'Host') { $this->setHeader($key, $value); } elseif ($value instanceof HeaderInterface) { $this->addHeader($key, $value); } else { foreach ((array) $value as $v) { $this->addHeader($key, $v); } } } } $this->setState(self::STATE_NEW); } public function __clone() { if ($this->eventDispatcher) { $this->eventDispatcher = clone $this->eventDispatcher; } $this->curlOptions = clone $this->curlOptions; $this->params = clone $this->params; $this->url = clone $this->url; $this->response = $this->responseBody = null; $this->headers = clone $this->headers; $this->setState(RequestInterface::STATE_NEW); $this->dispatch('request.clone', array('request' => $this)); } /** * Get the HTTP request as a string * * @return string */ public function __toString() { return $this->getRawHeaders() . "\r\n\r\n"; } /** * Default method that will throw exceptions if an unsuccessful response is received. * * @param Event $event Received * @throws BadResponseException if the response is not successful */ public static function onRequestError(Event $event) { $e = BadResponseException::factory($event['request'], $event['response']); $event['request']->setState(self::STATE_ERROR, array('exception' => $e) + $event->toArray()); throw $e; } public function setClient(ClientInterface $client) { $this->client = $client; return $this; } public function getClient() { return $this->client; } public function getRawHeaders() { $protocolVersion = $this->protocolVersion ?: '1.1'; return trim($this->method . ' ' . $this->getResource()) . ' ' . strtoupper(str_replace('https', 'http', $this->url->getScheme())) . '/' . $protocolVersion . "\r\n" . implode("\r\n", $this->getHeaderLines()); } public function setUrl($url) { if ($url instanceof Url) { $this->url = $url; } else { $this->url = Url::factory($url); } // Update the port and host header $this->setPort($this->url->getPort()); if ($this->url->getUsername() || $this->url->getPassword()) { $this->setAuth($this->url->getUsername(), $this->url->getPassword()); // Remove the auth info from the URL $this->url->setUsername(null); $this->url->setPassword(null); } return $this; } public function send() { if (!$this->client) { throw new RuntimeException('A client must be set on the request'); } return $this->client->send($this); } public function getResponse() { return $this->response; } public function getQuery($asString = false) { return $asString ? (string) $this->url->getQuery() : $this->url->getQuery(); } public function getMethod() { return $this->method; } public function getScheme() { return $this->url->getScheme(); } public function setScheme($scheme) { $this->url->setScheme($scheme); return $this; } public function getHost() { return $this->url->getHost(); } public function setHost($host) { $this->url->setHost($host); $this->setPort($this->url->getPort()); return $this; } public function getProtocolVersion() { return $this->protocolVersion; } public function setProtocolVersion($protocol) { $this->protocolVersion = $protocol; return $this; } public function getPath() { return '/' . ltrim($this->url->getPath(), '/'); } public function setPath($path) { $this->url->setPath($path); return $this; } public function getPort() { return $this->url->getPort(); } public function setPort($port) { $this->url->setPort($port); // Include the port in the Host header if it is not the default port for the scheme of the URL $scheme = $this->url->getScheme(); if (($scheme == 'http' && $port != 80) || ($scheme == 'https' && $port != 443)) { $this->headers['host'] = $this->headerFactory->createHeader('Host', $this->url->getHost() . ':' . $port); } else { $this->headers['host'] = $this->headerFactory->createHeader('Host', $this->url->getHost()); } return $this; } public function getUsername() { return $this->username; } public function getPassword() { return $this->password; } public function setAuth($user, $password = '', $scheme = CURLAUTH_BASIC) { static $authMap = array( 'basic' => CURLAUTH_BASIC, 'digest' => CURLAUTH_DIGEST, 'ntlm' => CURLAUTH_NTLM, 'any' => CURLAUTH_ANY ); // If we got false or null, disable authentication if (!$user) { $this->password = $this->username = null; $this->removeHeader('Authorization'); $this->getCurlOptions()->remove(CURLOPT_HTTPAUTH); return $this; } if (!is_numeric($scheme)) { $scheme = strtolower($scheme); if (!isset($authMap[$scheme])) { throw new InvalidArgumentException($scheme . ' is not a valid authentication type'); } $scheme = $authMap[$scheme]; } $this->username = $user; $this->password = $password; // Bypass CURL when using basic auth to promote connection reuse if ($scheme == CURLAUTH_BASIC) { $this->getCurlOptions()->remove(CURLOPT_HTTPAUTH); $this->setHeader('Authorization', 'Basic ' . base64_encode($this->username . ':' . $this->password)); } else { $this->getCurlOptions() ->set(CURLOPT_HTTPAUTH, $scheme) ->set(CURLOPT_USERPWD, $this->username . ':' . $this->password); } return $this; } public function getResource() { $resource = $this->getPath(); if ($query = (string) $this->url->getQuery()) { $resource .= '?' . $query; } return $resource; } public function getUrl($asObject = false) { return $asObject ? clone $this->url : (string) $this->url; } public function getState() { return $this->state; } public function setState($state, array $context = array()) { $oldState = $this->state; $this->state = $state; switch ($state) { case self::STATE_NEW: $this->response = null; break; case self::STATE_TRANSFER: if ($oldState !== $state) { // Fix Content-Length and Transfer-Encoding collisions if ($this->hasHeader('Transfer-Encoding') && $this->hasHeader('Content-Length')) { $this->removeHeader('Transfer-Encoding'); } $this->dispatch('request.before_send', array('request' => $this)); } break; case self::STATE_COMPLETE: if ($oldState !== $state) { $this->processResponse($context); $this->responseBody = null; } break; case self::STATE_ERROR: if (isset($context['exception'])) { $this->dispatch('request.exception', array( 'request' => $this, 'response' => isset($context['response']) ? $context['response'] : $this->response, 'exception' => isset($context['exception']) ? $context['exception'] : null )); } } return $this->state; } public function getCurlOptions() { return $this->curlOptions; } public function startResponse(Response $response) { $this->state = self::STATE_TRANSFER; $response->setEffectiveUrl((string) $this->getUrl()); $this->response = $response; return $this; } public function setResponse(Response $response, $queued = false) { $response->setEffectiveUrl((string) $this->url); if ($queued) { $ed = $this->getEventDispatcher(); $ed->addListener('request.before_send', $f = function ($e) use ($response, &$f, $ed) { $e['request']->setResponse($response); $ed->removeListener('request.before_send', $f); }, -9999); } else { $this->response = $response; // If a specific response body is specified, then use it instead of the response's body if ($this->responseBody && !$this->responseBody->getCustomData('default') && !$response->isRedirect()) { $this->getResponseBody()->write((string) $this->response->getBody()); } else { $this->responseBody = $this->response->getBody(); } $this->setState(self::STATE_COMPLETE); } return $this; } public function setResponseBody($body) { // Attempt to open a file for writing if a string was passed if (is_string($body)) { // @codeCoverageIgnoreStart if (!($body = fopen($body, 'w+'))) { throw new InvalidArgumentException('Could not open ' . $body . ' for writing'); } // @codeCoverageIgnoreEnd } $this->responseBody = EntityBody::factory($body); return $this; } public function getResponseBody() { if ($this->responseBody === null) { $this->responseBody = EntityBody::factory()->setCustomData('default', true); } return $this->responseBody; } /** * Determine if the response body is repeatable (readable + seekable) * * @return bool * @deprecated Use getResponseBody()->isSeekable() * @codeCoverageIgnore */ public function isResponseBodyRepeatable() { Version::warn(__METHOD__ . ' is deprecated. Use $request->getResponseBody()->isRepeatable()'); return !$this->responseBody ? true : $this->responseBody->isRepeatable(); } public function getCookies() { if ($cookie = $this->getHeader('Cookie')) { $data = ParserRegistry::getInstance()->getParser('cookie')->parseCookie($cookie); return $data['cookies']; } return array(); } public function getCookie($name) { $cookies = $this->getCookies(); return isset($cookies[$name]) ? $cookies[$name] : null; } public function addCookie($name, $value) { if (!$this->hasHeader('Cookie')) { $this->setHeader('Cookie', "{$name}={$value}"); } else { $this->getHeader('Cookie')->add("{$name}={$value}"); } // Always use semicolons to separate multiple cookie headers $this->getHeader('Cookie')->setGlue(';'); return $this; } public function removeCookie($name) { if ($cookie = $this->getHeader('Cookie')) { foreach ($cookie as $cookieValue) { if (strpos($cookieValue, $name . '=') === 0) { $cookie->removeValue($cookieValue); } } } return $this; } public function setEventDispatcher(EventDispatcherInterface $eventDispatcher) { $this->eventDispatcher = $eventDispatcher; $this->eventDispatcher->addListener('request.error', array(__CLASS__, 'onRequestError'), -255); return $this; } public function getEventDispatcher() { if (!$this->eventDispatcher) { $this->setEventDispatcher(new EventDispatcher()); } return $this->eventDispatcher; } public function dispatch($eventName, array $context = array()) { $context['request'] = $this; return $this->getEventDispatcher()->dispatch($eventName, new Event($context)); } public function addSubscriber(EventSubscriberInterface $subscriber) { $this->getEventDispatcher()->addSubscriber($subscriber); return $this; } /** * Get an array containing the request and response for event notifications * * @return array */ protected function getEventArray() { return array( 'request' => $this, 'response' => $this->response ); } /** * Process a received response * * @param array $context Contextual information * @throws RequestException|BadResponseException on unsuccessful responses */ protected function processResponse(array $context = array()) { if (!$this->response) { // If no response, then processResponse shouldn't have been called $e = new RequestException('Error completing request'); $e->setRequest($this); throw $e; } $this->state = self::STATE_COMPLETE; // A request was sent, but we don't know if we'll send more or if the final response will be successful $this->dispatch('request.sent', $this->getEventArray() + $context); // Some response processors will remove the response or reset the state (example: ExponentialBackoffPlugin) if ($this->state == RequestInterface::STATE_COMPLETE) { // The request completed, so the HTTP transaction is complete $this->dispatch('request.complete', $this->getEventArray()); // If the response is bad, allow listeners to modify it or throw exceptions. You can change the response by // modifying the Event object in your listeners or calling setResponse() on the request if ($this->response->isError()) { $event = new Event($this->getEventArray()); $this->getEventDispatcher()->dispatch('request.error', $event); // Allow events of request.error to quietly change the response if ($event['response'] !== $this->response) { $this->response = $event['response']; } } // If a successful response was received, dispatch an event if ($this->response->isSuccessful()) { $this->dispatch('request.success', $this->getEventArray()); } } } /** * @deprecated Use Guzzle\Plugin\Cache\DefaultCanCacheStrategy * @codeCoverageIgnore */ public function canCache() { Version::warn(__METHOD__ . ' is deprecated. Use Guzzle\Plugin\Cache\DefaultCanCacheStrategy.'); if (class_exists('Guzzle\Plugin\Cache\DefaultCanCacheStrategy')) { $canCache = new \Guzzle\Plugin\Cache\DefaultCanCacheStrategy(); return $canCache->canCacheRequest($this); } else { return false; } } /** * @deprecated Use the history plugin (not emitting a warning as this is built-into the RedirectPlugin for now) * @codeCoverageIgnore */ public function setIsRedirect($isRedirect) { $this->isRedirect = $isRedirect; return $this; } /** * @deprecated Use the history plugin * @codeCoverageIgnore */ public function isRedirect() { Version::warn(__METHOD__ . ' is deprecated. Use the HistoryPlugin to track this.'); return $this->isRedirect; } } methods = array_flip(get_class_methods(__CLASS__)); } public function fromMessage($message) { $parsed = ParserRegistry::getInstance()->getParser('message')->parseRequest($message); if (!$parsed) { return false; } $request = $this->fromParts($parsed['method'], $parsed['request_url'], $parsed['headers'], $parsed['body'], $parsed['protocol'], $parsed['version']); // EntityEnclosingRequest adds an "Expect: 100-Continue" header when using a raw request body for PUT or POST // requests. This factory method should accurately reflect the message, so here we are removing the Expect // header if one was not supplied in the message. if (!isset($parsed['headers']['Expect']) && !isset($parsed['headers']['expect'])) { $request->removeHeader('Expect'); } return $request; } public function fromParts( $method, array $urlParts, $headers = null, $body = null, $protocol = 'HTTP', $protocolVersion = '1.1' ) { return $this->create($method, Url::buildUrl($urlParts), $headers, $body) ->setProtocolVersion($protocolVersion); } public function create($method, $url, $headers = null, $body = null, array $options = array()) { $method = strtoupper($method); if ($method == 'GET' || $method == 'HEAD' || $method == 'TRACE' || $method == 'OPTIONS') { // Handle non-entity-enclosing request methods $request = new $this->requestClass($method, $url, $headers); if ($body) { // The body is where the response body will be stored $type = gettype($body); if ($type == 'string' || $type == 'resource' || $type == 'object') { $request->setResponseBody($body); } } } else { // Create an entity enclosing request by default $request = new $this->entityEnclosingRequestClass($method, $url, $headers); if ($body || $body === '0') { // Add POST fields and files to an entity enclosing request if an array is used if (is_array($body) || $body instanceof Collection) { // Normalize PHP style cURL uploads with a leading '@' symbol foreach ($body as $key => $value) { if (is_string($value) && substr($value, 0, 1) == '@') { $request->addPostFile($key, $value); unset($body[$key]); } } // Add the fields if they are still present and not all files $request->addPostFields($body); } else { // Add a raw entity body body to the request $request->setBody($body, (string) $request->getHeader('Content-Type')); if ((string) $request->getHeader('Transfer-Encoding') == 'chunked') { $request->removeHeader('Content-Length'); } } } } if ($options) { $this->applyOptions($request, $options); } return $request; } /** * Clone a request while changing the method. Emulates the behavior of * {@see Guzzle\Http\Message\Request::clone}, but can change the HTTP method. * * @param RequestInterface $request Request to clone * @param string $method Method to set * * @return RequestInterface */ public function cloneRequestWithMethod(RequestInterface $request, $method) { // Create the request with the same client if possible if ($request->getClient()) { $cloned = $request->getClient()->createRequest($method, $request->getUrl(), $request->getHeaders()); } else { $cloned = $this->create($method, $request->getUrl(), $request->getHeaders()); } $cloned->getCurlOptions()->replace($request->getCurlOptions()->toArray()); $cloned->setEventDispatcher(clone $request->getEventDispatcher()); // Ensure that that the Content-Length header is not copied if changing to GET or HEAD if (!($cloned instanceof EntityEnclosingRequestInterface)) { $cloned->removeHeader('Content-Length'); } elseif ($request instanceof EntityEnclosingRequestInterface) { $cloned->setBody($request->getBody()); } $cloned->getParams()->replace($request->getParams()->toArray()); $cloned->dispatch('request.clone', array('request' => $cloned)); return $cloned; } public function applyOptions(RequestInterface $request, array $options = array(), $flags = self::OPTIONS_NONE) { // Iterate over each key value pair and attempt to apply a config using function visitors foreach ($options as $key => $value) { $method = "visit_{$key}"; if (isset($this->methods[$method])) { $this->{$method}($request, $value, $flags); } } } protected function visit_headers(RequestInterface $request, $value, $flags) { if (!is_array($value)) { throw new InvalidArgumentException('headers value must be an array'); } if ($flags & self::OPTIONS_AS_DEFAULTS) { // Merge headers in but do not overwrite existing values foreach ($value as $key => $header) { if (!$request->hasHeader($key)) { $request->setHeader($key, $header); } } } else { $request->addHeaders($value); } } protected function visit_body(RequestInterface $request, $value, $flags) { if ($request instanceof EntityEnclosingRequestInterface) { $request->setBody($value); } else { throw new InvalidArgumentException('Attempting to set a body on a non-entity-enclosing request'); } } protected function visit_allow_redirects(RequestInterface $request, $value, $flags) { if ($value === false) { $request->getParams()->set(RedirectPlugin::DISABLE, true); } } protected function visit_auth(RequestInterface $request, $value, $flags) { if (!is_array($value)) { throw new InvalidArgumentException('auth value must be an array'); } $request->setAuth($value[0], isset($value[1]) ? $value[1] : null, isset($value[2]) ? $value[2] : 'basic'); } protected function visit_query(RequestInterface $request, $value, $flags) { if (!is_array($value)) { throw new InvalidArgumentException('query value must be an array'); } if ($flags & self::OPTIONS_AS_DEFAULTS) { // Merge query string values in but do not overwrite existing values $query = $request->getQuery(); $query->overwriteWith(array_diff_key($value, $query->toArray())); } else { $request->getQuery()->overwriteWith($value); } } protected function visit_cookies(RequestInterface $request, $value, $flags) { if (!is_array($value)) { throw new InvalidArgumentException('cookies value must be an array'); } foreach ($value as $name => $v) { $request->addCookie($name, $v); } } protected function visit_events(RequestInterface $request, $value, $flags) { if (!is_array($value)) { throw new InvalidArgumentException('events value must be an array'); } foreach ($value as $name => $method) { if (is_array($method)) { $request->getEventDispatcher()->addListener($name, $method[0], $method[1]); } else { $request->getEventDispatcher()->addListener($name, $method); } } } protected function visit_plugins(RequestInterface $request, $value, $flags) { if (!is_array($value)) { throw new InvalidArgumentException('plugins value must be an array'); } foreach ($value as $plugin) { $request->addSubscriber($plugin); } } protected function visit_exceptions(RequestInterface $request, $value, $flags) { if ($value === false || $value === 0) { $dispatcher = $request->getEventDispatcher(); foreach ($dispatcher->getListeners('request.error') as $listener) { if (is_array($listener) && $listener[0] == 'Guzzle\Http\Message\Request' && $listener[1] = 'onRequestError') { $dispatcher->removeListener('request.error', $listener); break; } } } } protected function visit_save_to(RequestInterface $request, $value, $flags) { $request->setResponseBody($value); } protected function visit_params(RequestInterface $request, $value, $flags) { if (!is_array($value)) { throw new InvalidArgumentException('params value must be an array'); } $request->getParams()->overwriteWith($value); } protected function visit_timeout(RequestInterface $request, $value, $flags) { if (defined('CURLOPT_TIMEOUT_MS')) { $request->getCurlOptions()->set(CURLOPT_TIMEOUT_MS, $value * 1000); } else { $request->getCurlOptions()->set(CURLOPT_TIMEOUT, $value); } } protected function visit_connect_timeout(RequestInterface $request, $value, $flags) { if (defined('CURLOPT_CONNECTTIMEOUT_MS')) { $request->getCurlOptions()->set(CURLOPT_CONNECTTIMEOUT_MS, $value * 1000); } else { $request->getCurlOptions()->set(CURLOPT_CONNECTTIMEOUT, $value); } } protected function visit_debug(RequestInterface $request, $value, $flags) { if ($value) { $request->getCurlOptions()->set(CURLOPT_VERBOSE, true); } } protected function visit_verify(RequestInterface $request, $value, $flags) { $curl = $request->getCurlOptions(); if ($value === true || is_string($value)) { $curl[CURLOPT_SSL_VERIFYHOST] = 2; $curl[CURLOPT_SSL_VERIFYPEER] = true; if ($value !== true) { $curl[CURLOPT_CAINFO] = $value; } } elseif ($value === false) { unset($curl[CURLOPT_CAINFO]); $curl[CURLOPT_SSL_VERIFYHOST] = 0; $curl[CURLOPT_SSL_VERIFYPEER] = false; } } protected function visit_proxy(RequestInterface $request, $value, $flags) { $request->getCurlOptions()->set(CURLOPT_PROXY, $value, $flags); } protected function visit_cert(RequestInterface $request, $value, $flags) { if (is_array($value)) { $request->getCurlOptions()->set(CURLOPT_SSLCERT, $value[0]); $request->getCurlOptions()->set(CURLOPT_SSLCERTPASSWD, $value[1]); } else { $request->getCurlOptions()->set(CURLOPT_SSLCERT, $value); } } protected function visit_ssl_key(RequestInterface $request, $value, $flags) { if (is_array($value)) { $request->getCurlOptions()->set(CURLOPT_SSLKEY, $value[0]); $request->getCurlOptions()->set(CURLOPT_SSLKEYPASSWD, $value[1]); } else { $request->getCurlOptions()->set(CURLOPT_SSLKEY, $value); } } } 'Continue', 101 => 'Switching Protocols', 102 => 'Processing', 200 => 'OK', 201 => 'Created', 202 => 'Accepted', 203 => 'Non-Authoritative Information', 204 => 'No Content', 205 => 'Reset Content', 206 => 'Partial Content', 207 => 'Multi-Status', 208 => 'Already Reported', 226 => 'IM Used', 300 => 'Multiple Choices', 301 => 'Moved Permanently', 302 => 'Found', 303 => 'See Other', 304 => 'Not Modified', 305 => 'Use Proxy', 307 => 'Temporary Redirect', 308 => 'Permanent Redirect', 400 => 'Bad Request', 401 => 'Unauthorized', 402 => 'Payment Required', 403 => 'Forbidden', 404 => 'Not Found', 405 => 'Method Not Allowed', 406 => 'Not Acceptable', 407 => 'Proxy Authentication Required', 408 => 'Request Timeout', 409 => 'Conflict', 410 => 'Gone', 411 => 'Length Required', 412 => 'Precondition Failed', 413 => 'Request Entity Too Large', 414 => 'Request-URI Too Long', 415 => 'Unsupported Media Type', 416 => 'Requested Range Not Satisfiable', 417 => 'Expectation Failed', 422 => 'Unprocessable Entity', 423 => 'Locked', 424 => 'Failed Dependency', 425 => 'Reserved for WebDAV advanced collections expired proposal', 426 => 'Upgrade required', 428 => 'Precondition Required', 429 => 'Too Many Requests', 431 => 'Request Header Fields Too Large', 500 => 'Internal Server Error', 501 => 'Not Implemented', 502 => 'Bad Gateway', 503 => 'Service Unavailable', 504 => 'Gateway Timeout', 505 => 'HTTP Version Not Supported', 506 => 'Variant Also Negotiates (Experimental)', 507 => 'Insufficient Storage', 508 => 'Loop Detected', 510 => 'Not Extended', 511 => 'Network Authentication Required', ); /** @var EntityBodyInterface The response body */ protected $body; /** @var string The reason phrase of the response (human readable code) */ protected $reasonPhrase; /** @var string The status code of the response */ protected $statusCode; /** @var array Information about the request */ protected $info = array(); /** @var string The effective URL that returned this response */ protected $effectiveUrl; /** @var array Cacheable response codes (see RFC 2616:13.4) */ protected static $cacheResponseCodes = array(200, 203, 206, 300, 301, 410); /** * Create a new Response based on a raw response message * * @param string $message Response message * * @return self|bool Returns false on error */ public static function fromMessage($message) { $data = ParserRegistry::getInstance()->getParser('message')->parseResponse($message); if (!$data) { return false; } $response = new static($data['code'], $data['headers'], $data['body']); $response->setProtocol($data['protocol'], $data['version']) ->setStatus($data['code'], $data['reason_phrase']); // Set the appropriate Content-Length if the one set is inaccurate (e.g. setting to X) $contentLength = (string) $response->getHeader('Content-Length'); $actualLength = strlen($data['body']); if (strlen($data['body']) > 0 && $contentLength != $actualLength) { $response->setHeader('Content-Length', $actualLength); } return $response; } /** * Construct the response * * @param string $statusCode The response status code (e.g. 200, 404, etc) * @param ToArrayInterface|array $headers The response headers * @param string|resource|EntityBodyInterface $body The body of the response * * @throws BadResponseException if an invalid response code is given */ public function __construct($statusCode, $headers = null, $body = null) { parent::__construct(); $this->setStatus($statusCode); $this->body = EntityBody::factory($body !== null ? $body : ''); if ($headers) { if (is_array($headers)) { $this->setHeaders($headers); } elseif ($headers instanceof ToArrayInterface) { $this->setHeaders($headers->toArray()); } else { throw new BadResponseException('Invalid headers argument received'); } } } /** * @return string */ public function __toString() { return $this->getMessage(); } public function serialize() { return json_encode(array( 'status' => $this->statusCode, 'body' => (string) $this->body, 'headers' => $this->headers->toArray() )); } public function unserialize($serialize) { $data = json_decode($serialize, true); $this->__construct($data['status'], $data['headers'], $data['body']); } /** * Get the response entity body * * @param bool $asString Set to TRUE to return a string of the body rather than a full body object * * @return EntityBodyInterface|string */ public function getBody($asString = false) { return $asString ? (string) $this->body : $this->body; } /** * Set the response entity body * * @param EntityBodyInterface|string $body Body to set * * @return self */ public function setBody($body) { $this->body = EntityBody::factory($body); return $this; } /** * Set the protocol and protocol version of the response * * @param string $protocol Response protocol * @param string $version Protocol version * * @return self */ public function setProtocol($protocol, $version) { $this->protocol = $protocol; $this->protocolVersion = $version; return $this; } /** * Get the protocol used for the response (e.g. HTTP) * * @return string */ public function getProtocol() { return $this->protocol; } /** * Get the HTTP protocol version * * @return string */ public function getProtocolVersion() { return $this->protocolVersion; } /** * Get a cURL transfer information * * @param string $key A single statistic to check * * @return array|string|null Returns all stats if no key is set, a single stat if a key is set, or null if a key * is set and not found * @link http://www.php.net/manual/en/function.curl-getinfo.php */ public function getInfo($key = null) { if ($key === null) { return $this->info; } elseif (array_key_exists($key, $this->info)) { return $this->info[$key]; } else { return null; } } /** * Set the transfer information * * @param array $info Array of cURL transfer stats * * @return self */ public function setInfo(array $info) { $this->info = $info; return $this; } /** * Set the response status * * @param int $statusCode Response status code to set * @param string $reasonPhrase Response reason phrase * * @return self * @throws BadResponseException when an invalid response code is received */ public function setStatus($statusCode, $reasonPhrase = '') { $this->statusCode = (int) $statusCode; if (!$reasonPhrase && isset(self::$statusTexts[$this->statusCode])) { $this->reasonPhrase = self::$statusTexts[$this->statusCode]; } else { $this->reasonPhrase = $reasonPhrase; } return $this; } /** * Get the response status code * * @return integer */ public function getStatusCode() { return $this->statusCode; } /** * Get the entire response as a string * * @return string */ public function getMessage() { $message = $this->getRawHeaders(); // Only include the body in the message if the size is < 2MB $size = $this->body->getSize(); if ($size < 2097152) { $message .= (string) $this->body; } return $message; } /** * Get the the raw message headers as a string * * @return string */ public function getRawHeaders() { $headers = 'HTTP/1.1 ' . $this->statusCode . ' ' . $this->reasonPhrase . "\r\n"; $lines = $this->getHeaderLines(); if (!empty($lines)) { $headers .= implode("\r\n", $lines) . "\r\n"; } return $headers . "\r\n"; } /** * Get the response reason phrase- a human readable version of the numeric * status code * * @return string */ public function getReasonPhrase() { return $this->reasonPhrase; } /** * Get the Accept-Ranges HTTP header * * @return string Returns what partial content range types this server supports. */ public function getAcceptRanges() { return (string) $this->getHeader('Accept-Ranges'); } /** * Calculate the age of the response * * @return integer */ public function calculateAge() { $age = $this->getHeader('Age'); if ($age === null && $this->getDate()) { $age = time() - strtotime($this->getDate()); } return $age === null ? null : (int) (string) $age; } /** * Get the Age HTTP header * * @return integer|null Returns the age the object has been in a proxy cache in seconds. */ public function getAge() { return (string) $this->getHeader('Age'); } /** * Get the Allow HTTP header * * @return string|null Returns valid actions for a specified resource. To be used for a 405 Method not allowed. */ public function getAllow() { return (string) $this->getHeader('Allow'); } /** * Check if an HTTP method is allowed by checking the Allow response header * * @param string $method Method to check * * @return bool */ public function isMethodAllowed($method) { $allow = $this->getHeader('Allow'); if ($allow) { foreach (explode(',', $allow) as $allowable) { if (!strcasecmp(trim($allowable), $method)) { return true; } } } return false; } /** * Get the Cache-Control HTTP header * * @return string */ public function getCacheControl() { return (string) $this->getHeader('Cache-Control'); } /** * Get the Connection HTTP header * * @return string */ public function getConnection() { return (string) $this->getHeader('Connection'); } /** * Get the Content-Encoding HTTP header * * @return string|null */ public function getContentEncoding() { return (string) $this->getHeader('Content-Encoding'); } /** * Get the Content-Language HTTP header * * @return string|null Returns the language the content is in. */ public function getContentLanguage() { return (string) $this->getHeader('Content-Language'); } /** * Get the Content-Length HTTP header * * @return integer Returns the length of the response body in bytes */ public function getContentLength() { return (int) (string) $this->getHeader('Content-Length'); } /** * Get the Content-Location HTTP header * * @return string|null Returns an alternate location for the returned data (e.g /index.htm) */ public function getContentLocation() { return (string) $this->getHeader('Content-Location'); } /** * Get the Content-Disposition HTTP header * * @return string|null Returns the Content-Disposition header */ public function getContentDisposition() { return (string) $this->getHeader('Content-Disposition'); } /** * Get the Content-MD5 HTTP header * * @return string|null Returns a Base64-encoded binary MD5 sum of the content of the response. */ public function getContentMd5() { return (string) $this->getHeader('Content-MD5'); } /** * Get the Content-Range HTTP header * * @return string Returns where in a full body message this partial message belongs (e.g. bytes 21010-47021/47022). */ public function getContentRange() { return (string) $this->getHeader('Content-Range'); } /** * Get the Content-Type HTTP header * * @return string Returns the mime type of this content. */ public function getContentType() { return (string) $this->getHeader('Content-Type'); } /** * Checks if the Content-Type is of a certain type. This is useful if the * Content-Type header contains charset information and you need to know if * the Content-Type matches a particular type. * * @param string $type Content type to check against * * @return bool */ public function isContentType($type) { return stripos($this->getHeader('Content-Type'), $type) !== false; } /** * Get the Date HTTP header * * @return string|null Returns the date and time that the message was sent. */ public function getDate() { return (string) $this->getHeader('Date'); } /** * Get the ETag HTTP header * * @return string|null Returns an identifier for a specific version of a resource, often a Message digest. */ public function getEtag() { return (string) $this->getHeader('ETag'); } /** * Get the Expires HTTP header * * @return string|null Returns the date/time after which the response is considered stale. */ public function getExpires() { return (string) $this->getHeader('Expires'); } /** * Get the Last-Modified HTTP header * * @return string|null Returns the last modified date for the requested object, in RFC 2822 format * (e.g. Tue, 15 Nov 1994 12:45:26 GMT) */ public function getLastModified() { return (string) $this->getHeader('Last-Modified'); } /** * Get the Location HTTP header * * @return string|null Used in redirection, or when a new resource has been created. */ public function getLocation() { return (string) $this->getHeader('Location'); } /** * Get the Pragma HTTP header * * @return Header|null Returns the implementation-specific headers that may have various effects anywhere along * the request-response chain. */ public function getPragma() { return (string) $this->getHeader('Pragma'); } /** * Get the Proxy-Authenticate HTTP header * * @return string|null Authentication to access the proxy (e.g. Basic) */ public function getProxyAuthenticate() { return (string) $this->getHeader('Proxy-Authenticate'); } /** * Get the Retry-After HTTP header * * @return int|null If an entity is temporarily unavailable, this instructs the client to try again after a * specified period of time. */ public function getRetryAfter() { return (string) $this->getHeader('Retry-After'); } /** * Get the Server HTTP header * * @return string|null A name for the server */ public function getServer() { return (string) $this->getHeader('Server'); } /** * Get the Set-Cookie HTTP header * * @return string|null An HTTP cookie. */ public function getSetCookie() { return (string) $this->getHeader('Set-Cookie'); } /** * Get the Trailer HTTP header * * @return string|null The Trailer general field value indicates that the given set of header fields is present in * the trailer of a message encoded with chunked transfer-coding. */ public function getTrailer() { return (string) $this->getHeader('Trailer'); } /** * Get the Transfer-Encoding HTTP header * * @return string|null The form of encoding used to safely transfer the entity to the user */ public function getTransferEncoding() { return (string) $this->getHeader('Transfer-Encoding'); } /** * Get the Vary HTTP header * * @return string|null Tells downstream proxies how to match future request headers to decide whether the cached * response can be used rather than requesting a fresh one from the origin server. */ public function getVary() { return (string) $this->getHeader('Vary'); } /** * Get the Via HTTP header * * @return string|null Informs the client of proxies through which the response was sent. */ public function getVia() { return (string) $this->getHeader('Via'); } /** * Get the Warning HTTP header * * @return string|null A general warning about possible problems with the entity body */ public function getWarning() { return (string) $this->getHeader('Warning'); } /** * Get the WWW-Authenticate HTTP header * * @return string|null Indicates the authentication scheme that should be used to access the requested entity */ public function getWwwAuthenticate() { return (string) $this->getHeader('WWW-Authenticate'); } /** * Checks if HTTP Status code is a Client Error (4xx) * * @return bool */ public function isClientError() { return $this->statusCode >= 400 && $this->statusCode < 500; } /** * Checks if HTTP Status code is Server OR Client Error (4xx or 5xx) * * @return boolean */ public function isError() { return $this->isClientError() || $this->isServerError(); } /** * Checks if HTTP Status code is Information (1xx) * * @return bool */ public function isInformational() { return $this->statusCode < 200; } /** * Checks if HTTP Status code is a Redirect (3xx) * * @return bool */ public function isRedirect() { return $this->statusCode >= 300 && $this->statusCode < 400; } /** * Checks if HTTP Status code is Server Error (5xx) * * @return bool */ public function isServerError() { return $this->statusCode >= 500 && $this->statusCode < 600; } /** * Checks if HTTP Status code is Successful (2xx | 304) * * @return bool */ public function isSuccessful() { return ($this->statusCode >= 200 && $this->statusCode < 300) || $this->statusCode == 304; } /** * Check if the response can be cached based on the response headers * * @return bool Returns TRUE if the response can be cached or false if not */ public function canCache() { // Check if the response is cacheable based on the code if (!in_array((int) $this->getStatusCode(), self::$cacheResponseCodes)) { return false; } // Make sure a valid body was returned and can be cached if ((!$this->getBody()->isReadable() || !$this->getBody()->isSeekable()) && ($this->getContentLength() > 0 || $this->getTransferEncoding() == 'chunked')) { return false; } // Never cache no-store resources (this is a private cache, so private // can be cached) if ($this->getHeader('Cache-Control') && $this->getHeader('Cache-Control')->hasDirective('no-store')) { return false; } return $this->isFresh() || $this->getFreshness() === null || $this->canValidate(); } /** * Gets the number of seconds from the current time in which this response is still considered fresh * * @return int|null Returns the number of seconds */ public function getMaxAge() { if ($header = $this->getHeader('Cache-Control')) { // s-max-age, then max-age, then Expires if ($age = $header->getDirective('s-maxage')) { return $age; } if ($age = $header->getDirective('max-age')) { return $age; } } if ($this->getHeader('Expires')) { return strtotime($this->getExpires()) - time(); } return null; } /** * Check if the response is considered fresh. * * A response is considered fresh when its age is less than or equal to the freshness lifetime (maximum age) of the * response. * * @return bool|null */ public function isFresh() { $fresh = $this->getFreshness(); return $fresh === null ? null : $fresh >= 0; } /** * Check if the response can be validated against the origin server using a conditional GET request. * * @return bool */ public function canValidate() { return $this->getEtag() || $this->getLastModified(); } /** * Get the freshness of the response by returning the difference of the maximum lifetime of the response and the * age of the response (max-age - age). * * Freshness values less than 0 mean that the response is no longer fresh and is ABS(freshness) seconds expired. * Freshness values of greater than zero is the number of seconds until the response is no longer fresh. A NULL * result means that no freshness information is available. * * @return int */ public function getFreshness() { $maxAge = $this->getMaxAge(); $age = $this->calculateAge(); return $maxAge && $age ? ($maxAge - $age) : null; } /** * Parse the JSON response body and return an array * * @return array|string|int|bool|float * @throws RuntimeException if the response body is not in JSON format */ public function json() { $data = json_decode((string) $this->body, true); if (JSON_ERROR_NONE !== json_last_error()) { throw new RuntimeException('Unable to parse response body into JSON: ' . json_last_error()); } return $data === null ? array() : $data; } /** * Parse the XML response body and return a \SimpleXMLElement. * * In order to prevent XXE attacks, this method disables loading external * entities. If you rely on external entities, then you must parse the * XML response manually by accessing the response body directly. * * @return \SimpleXMLElement * @throws RuntimeException if the response body is not in XML format * @link http://websec.io/2012/08/27/Preventing-XXE-in-PHP.html */ public function xml() { $errorMessage = null; $internalErrors = libxml_use_internal_errors(true); $disableEntities = libxml_disable_entity_loader(true); libxml_clear_errors(); try { $xml = new \SimpleXMLElement((string) $this->body ?: '', LIBXML_NONET); if ($error = libxml_get_last_error()) { $errorMessage = $error->message; } } catch (\Exception $e) { $errorMessage = $e->getMessage(); } libxml_clear_errors(); libxml_use_internal_errors($internalErrors); libxml_disable_entity_loader($disableEntities); if ($errorMessage) { throw new RuntimeException('Unable to parse response body into XML: ' . $errorMessage); } return $xml; } /** * Get the redirect count of this response * * @return int */ public function getRedirectCount() { return (int) $this->params->get(RedirectPlugin::REDIRECT_COUNT); } /** * Set the effective URL that resulted in this response (e.g. the last redirect URL) * * @param string $url The effective URL * * @return self */ public function setEffectiveUrl($url) { $this->effectiveUrl = $url; return $this; } /** * Get the effective URL that resulted in this response (e.g. the last redirect URL) * * @return string */ public function getEffectiveUrl() { return $this->effectiveUrl; } /** * @deprecated * @codeCoverageIgnore */ public function getPreviousResponse() { Version::warn(__METHOD__ . ' is deprecated. Use the HistoryPlugin.'); return null; } /** * @deprecated * @codeCoverageIgnore */ public function setRequest($request) { Version::warn(__METHOD__ . ' is deprecated'); return $this; } /** * @deprecated * @codeCoverageIgnore */ public function getRequest() { Version::warn(__METHOD__ . ' is deprecated'); return null; } } 'text/vnd.in3d.3dml', '3g2' => 'video/3gpp2', '3gp' => 'video/3gpp', '7z' => 'application/x-7z-compressed', 'aab' => 'application/x-authorware-bin', 'aac' => 'audio/x-aac', 'aam' => 'application/x-authorware-map', 'aas' => 'application/x-authorware-seg', 'abw' => 'application/x-abiword', 'ac' => 'application/pkix-attr-cert', 'acc' => 'application/vnd.americandynamics.acc', 'ace' => 'application/x-ace-compressed', 'acu' => 'application/vnd.acucobol', 'acutc' => 'application/vnd.acucorp', 'adp' => 'audio/adpcm', 'aep' => 'application/vnd.audiograph', 'afm' => 'application/x-font-type1', 'afp' => 'application/vnd.ibm.modcap', 'ahead' => 'application/vnd.ahead.space', 'ai' => 'application/postscript', 'aif' => 'audio/x-aiff', 'aifc' => 'audio/x-aiff', 'aiff' => 'audio/x-aiff', 'air' => 'application/vnd.adobe.air-application-installer-package+zip', 'ait' => 'application/vnd.dvb.ait', 'ami' => 'application/vnd.amiga.ami', 'apk' => 'application/vnd.android.package-archive', 'application' => 'application/x-ms-application', 'apr' => 'application/vnd.lotus-approach', 'asa' => 'text/plain', 'asax' => 'application/octet-stream', 'asc' => 'application/pgp-signature', 'ascx' => 'text/plain', 'asf' => 'video/x-ms-asf', 'ashx' => 'text/plain', 'asm' => 'text/x-asm', 'asmx' => 'text/plain', 'aso' => 'application/vnd.accpac.simply.aso', 'asp' => 'text/plain', 'aspx' => 'text/plain', 'asx' => 'video/x-ms-asf', 'atc' => 'application/vnd.acucorp', 'atom' => 'application/atom+xml', 'atomcat' => 'application/atomcat+xml', 'atomsvc' => 'application/atomsvc+xml', 'atx' => 'application/vnd.antix.game-component', 'au' => 'audio/basic', 'avi' => 'video/x-msvideo', 'aw' => 'application/applixware', 'axd' => 'text/plain', 'azf' => 'application/vnd.airzip.filesecure.azf', 'azs' => 'application/vnd.airzip.filesecure.azs', 'azw' => 'application/vnd.amazon.ebook', 'bat' => 'application/x-msdownload', 'bcpio' => 'application/x-bcpio', 'bdf' => 'application/x-font-bdf', 'bdm' => 'application/vnd.syncml.dm+wbxml', 'bed' => 'application/vnd.realvnc.bed', 'bh2' => 'application/vnd.fujitsu.oasysprs', 'bin' => 'application/octet-stream', 'bmi' => 'application/vnd.bmi', 'bmp' => 'image/bmp', 'book' => 'application/vnd.framemaker', 'box' => 'application/vnd.previewsystems.box', 'boz' => 'application/x-bzip2', 'bpk' => 'application/octet-stream', 'btif' => 'image/prs.btif', 'bz' => 'application/x-bzip', 'bz2' => 'application/x-bzip2', 'c' => 'text/x-c', 'c11amc' => 'application/vnd.cluetrust.cartomobile-config', 'c11amz' => 'application/vnd.cluetrust.cartomobile-config-pkg', 'c4d' => 'application/vnd.clonk.c4group', 'c4f' => 'application/vnd.clonk.c4group', 'c4g' => 'application/vnd.clonk.c4group', 'c4p' => 'application/vnd.clonk.c4group', 'c4u' => 'application/vnd.clonk.c4group', 'cab' => 'application/vnd.ms-cab-compressed', 'car' => 'application/vnd.curl.car', 'cat' => 'application/vnd.ms-pki.seccat', 'cc' => 'text/x-c', 'cct' => 'application/x-director', 'ccxml' => 'application/ccxml+xml', 'cdbcmsg' => 'application/vnd.contact.cmsg', 'cdf' => 'application/x-netcdf', 'cdkey' => 'application/vnd.mediastation.cdkey', 'cdmia' => 'application/cdmi-capability', 'cdmic' => 'application/cdmi-container', 'cdmid' => 'application/cdmi-domain', 'cdmio' => 'application/cdmi-object', 'cdmiq' => 'application/cdmi-queue', 'cdx' => 'chemical/x-cdx', 'cdxml' => 'application/vnd.chemdraw+xml', 'cdy' => 'application/vnd.cinderella', 'cer' => 'application/pkix-cert', 'cfc' => 'application/x-coldfusion', 'cfm' => 'application/x-coldfusion', 'cgm' => 'image/cgm', 'chat' => 'application/x-chat', 'chm' => 'application/vnd.ms-htmlhelp', 'chrt' => 'application/vnd.kde.kchart', 'cif' => 'chemical/x-cif', 'cii' => 'application/vnd.anser-web-certificate-issue-initiation', 'cil' => 'application/vnd.ms-artgalry', 'cla' => 'application/vnd.claymore', 'class' => 'application/java-vm', 'clkk' => 'application/vnd.crick.clicker.keyboard', 'clkp' => 'application/vnd.crick.clicker.palette', 'clkt' => 'application/vnd.crick.clicker.template', 'clkw' => 'application/vnd.crick.clicker.wordbank', 'clkx' => 'application/vnd.crick.clicker', 'clp' => 'application/x-msclip', 'cmc' => 'application/vnd.cosmocaller', 'cmdf' => 'chemical/x-cmdf', 'cml' => 'chemical/x-cml', 'cmp' => 'application/vnd.yellowriver-custom-menu', 'cmx' => 'image/x-cmx', 'cod' => 'application/vnd.rim.cod', 'com' => 'application/x-msdownload', 'conf' => 'text/plain', 'cpio' => 'application/x-cpio', 'cpp' => 'text/x-c', 'cpt' => 'application/mac-compactpro', 'crd' => 'application/x-mscardfile', 'crl' => 'application/pkix-crl', 'crt' => 'application/x-x509-ca-cert', 'cryptonote' => 'application/vnd.rig.cryptonote', 'cs' => 'text/plain', 'csh' => 'application/x-csh', 'csml' => 'chemical/x-csml', 'csp' => 'application/vnd.commonspace', 'css' => 'text/css', 'cst' => 'application/x-director', 'csv' => 'text/csv', 'cu' => 'application/cu-seeme', 'curl' => 'text/vnd.curl', 'cww' => 'application/prs.cww', 'cxt' => 'application/x-director', 'cxx' => 'text/x-c', 'dae' => 'model/vnd.collada+xml', 'daf' => 'application/vnd.mobius.daf', 'dataless' => 'application/vnd.fdsn.seed', 'davmount' => 'application/davmount+xml', 'dcr' => 'application/x-director', 'dcurl' => 'text/vnd.curl.dcurl', 'dd2' => 'application/vnd.oma.dd2+xml', 'ddd' => 'application/vnd.fujixerox.ddd', 'deb' => 'application/x-debian-package', 'def' => 'text/plain', 'deploy' => 'application/octet-stream', 'der' => 'application/x-x509-ca-cert', 'dfac' => 'application/vnd.dreamfactory', 'dic' => 'text/x-c', 'dir' => 'application/x-director', 'dis' => 'application/vnd.mobius.dis', 'dist' => 'application/octet-stream', 'distz' => 'application/octet-stream', 'djv' => 'image/vnd.djvu', 'djvu' => 'image/vnd.djvu', 'dll' => 'application/x-msdownload', 'dmg' => 'application/octet-stream', 'dms' => 'application/octet-stream', 'dna' => 'application/vnd.dna', 'doc' => 'application/msword', 'docm' => 'application/vnd.ms-word.document.macroenabled.12', 'docx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.document', 'dot' => 'application/msword', 'dotm' => 'application/vnd.ms-word.template.macroenabled.12', 'dotx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.template', 'dp' => 'application/vnd.osgi.dp', 'dpg' => 'application/vnd.dpgraph', 'dra' => 'audio/vnd.dra', 'dsc' => 'text/prs.lines.tag', 'dssc' => 'application/dssc+der', 'dtb' => 'application/x-dtbook+xml', 'dtd' => 'application/xml-dtd', 'dts' => 'audio/vnd.dts', 'dtshd' => 'audio/vnd.dts.hd', 'dump' => 'application/octet-stream', 'dvi' => 'application/x-dvi', 'dwf' => 'model/vnd.dwf', 'dwg' => 'image/vnd.dwg', 'dxf' => 'image/vnd.dxf', 'dxp' => 'application/vnd.spotfire.dxp', 'dxr' => 'application/x-director', 'ecelp4800' => 'audio/vnd.nuera.ecelp4800', 'ecelp7470' => 'audio/vnd.nuera.ecelp7470', 'ecelp9600' => 'audio/vnd.nuera.ecelp9600', 'ecma' => 'application/ecmascript', 'edm' => 'application/vnd.novadigm.edm', 'edx' => 'application/vnd.novadigm.edx', 'efif' => 'application/vnd.picsel', 'ei6' => 'application/vnd.pg.osasli', 'elc' => 'application/octet-stream', 'eml' => 'message/rfc822', 'emma' => 'application/emma+xml', 'eol' => 'audio/vnd.digital-winds', 'eot' => 'application/vnd.ms-fontobject', 'eps' => 'application/postscript', 'epub' => 'application/epub+zip', 'es3' => 'application/vnd.eszigno3+xml', 'esf' => 'application/vnd.epson.esf', 'et3' => 'application/vnd.eszigno3+xml', 'etx' => 'text/x-setext', 'exe' => 'application/x-msdownload', 'exi' => 'application/exi', 'ext' => 'application/vnd.novadigm.ext', 'ez' => 'application/andrew-inset', 'ez2' => 'application/vnd.ezpix-album', 'ez3' => 'application/vnd.ezpix-package', 'f' => 'text/x-fortran', 'f4v' => 'video/x-f4v', 'f77' => 'text/x-fortran', 'f90' => 'text/x-fortran', 'fbs' => 'image/vnd.fastbidsheet', 'fcs' => 'application/vnd.isac.fcs', 'fdf' => 'application/vnd.fdf', 'fe_launch' => 'application/vnd.denovo.fcselayout-link', 'fg5' => 'application/vnd.fujitsu.oasysgp', 'fgd' => 'application/x-director', 'fh' => 'image/x-freehand', 'fh4' => 'image/x-freehand', 'fh5' => 'image/x-freehand', 'fh7' => 'image/x-freehand', 'fhc' => 'image/x-freehand', 'fig' => 'application/x-xfig', 'fli' => 'video/x-fli', 'flo' => 'application/vnd.micrografx.flo', 'flv' => 'video/x-flv', 'flw' => 'application/vnd.kde.kivio', 'flx' => 'text/vnd.fmi.flexstor', 'fly' => 'text/vnd.fly', 'fm' => 'application/vnd.framemaker', 'fnc' => 'application/vnd.frogans.fnc', 'for' => 'text/x-fortran', 'fpx' => 'image/vnd.fpx', 'frame' => 'application/vnd.framemaker', 'fsc' => 'application/vnd.fsc.weblaunch', 'fst' => 'image/vnd.fst', 'ftc' => 'application/vnd.fluxtime.clip', 'fti' => 'application/vnd.anser-web-funds-transfer-initiation', 'fvt' => 'video/vnd.fvt', 'fxp' => 'application/vnd.adobe.fxp', 'fxpl' => 'application/vnd.adobe.fxp', 'fzs' => 'application/vnd.fuzzysheet', 'g2w' => 'application/vnd.geoplan', 'g3' => 'image/g3fax', 'g3w' => 'application/vnd.geospace', 'gac' => 'application/vnd.groove-account', 'gdl' => 'model/vnd.gdl', 'geo' => 'application/vnd.dynageo', 'gex' => 'application/vnd.geometry-explorer', 'ggb' => 'application/vnd.geogebra.file', 'ggt' => 'application/vnd.geogebra.tool', 'ghf' => 'application/vnd.groove-help', 'gif' => 'image/gif', 'gim' => 'application/vnd.groove-identity-message', 'gmx' => 'application/vnd.gmx', 'gnumeric' => 'application/x-gnumeric', 'gph' => 'application/vnd.flographit', 'gqf' => 'application/vnd.grafeq', 'gqs' => 'application/vnd.grafeq', 'gram' => 'application/srgs', 'gre' => 'application/vnd.geometry-explorer', 'grv' => 'application/vnd.groove-injector', 'grxml' => 'application/srgs+xml', 'gsf' => 'application/x-font-ghostscript', 'gtar' => 'application/x-gtar', 'gtm' => 'application/vnd.groove-tool-message', 'gtw' => 'model/vnd.gtw', 'gv' => 'text/vnd.graphviz', 'gxt' => 'application/vnd.geonext', 'h' => 'text/x-c', 'h261' => 'video/h261', 'h263' => 'video/h263', 'h264' => 'video/h264', 'hal' => 'application/vnd.hal+xml', 'hbci' => 'application/vnd.hbci', 'hdf' => 'application/x-hdf', 'hh' => 'text/x-c', 'hlp' => 'application/winhlp', 'hpgl' => 'application/vnd.hp-hpgl', 'hpid' => 'application/vnd.hp-hpid', 'hps' => 'application/vnd.hp-hps', 'hqx' => 'application/mac-binhex40', 'hta' => 'application/octet-stream', 'htc' => 'text/html', 'htke' => 'application/vnd.kenameaapp', 'htm' => 'text/html', 'html' => 'text/html', 'hvd' => 'application/vnd.yamaha.hv-dic', 'hvp' => 'application/vnd.yamaha.hv-voice', 'hvs' => 'application/vnd.yamaha.hv-script', 'i2g' => 'application/vnd.intergeo', 'icc' => 'application/vnd.iccprofile', 'ice' => 'x-conference/x-cooltalk', 'icm' => 'application/vnd.iccprofile', 'ico' => 'image/x-icon', 'ics' => 'text/calendar', 'ief' => 'image/ief', 'ifb' => 'text/calendar', 'ifm' => 'application/vnd.shana.informed.formdata', 'iges' => 'model/iges', 'igl' => 'application/vnd.igloader', 'igm' => 'application/vnd.insors.igm', 'igs' => 'model/iges', 'igx' => 'application/vnd.micrografx.igx', 'iif' => 'application/vnd.shana.informed.interchange', 'imp' => 'application/vnd.accpac.simply.imp', 'ims' => 'application/vnd.ms-ims', 'in' => 'text/plain', 'ini' => 'text/plain', 'ipfix' => 'application/ipfix', 'ipk' => 'application/vnd.shana.informed.package', 'irm' => 'application/vnd.ibm.rights-management', 'irp' => 'application/vnd.irepository.package+xml', 'iso' => 'application/octet-stream', 'itp' => 'application/vnd.shana.informed.formtemplate', 'ivp' => 'application/vnd.immervision-ivp', 'ivu' => 'application/vnd.immervision-ivu', 'jad' => 'text/vnd.sun.j2me.app-descriptor', 'jam' => 'application/vnd.jam', 'jar' => 'application/java-archive', 'java' => 'text/x-java-source', 'jisp' => 'application/vnd.jisp', 'jlt' => 'application/vnd.hp-jlyt', 'jnlp' => 'application/x-java-jnlp-file', 'joda' => 'application/vnd.joost.joda-archive', 'jpe' => 'image/jpeg', 'jpeg' => 'image/jpeg', 'jpg' => 'image/jpeg', 'jpgm' => 'video/jpm', 'jpgv' => 'video/jpeg', 'jpm' => 'video/jpm', 'js' => 'text/javascript', 'json' => 'application/json', 'kar' => 'audio/midi', 'karbon' => 'application/vnd.kde.karbon', 'kfo' => 'application/vnd.kde.kformula', 'kia' => 'application/vnd.kidspiration', 'kml' => 'application/vnd.google-earth.kml+xml', 'kmz' => 'application/vnd.google-earth.kmz', 'kne' => 'application/vnd.kinar', 'knp' => 'application/vnd.kinar', 'kon' => 'application/vnd.kde.kontour', 'kpr' => 'application/vnd.kde.kpresenter', 'kpt' => 'application/vnd.kde.kpresenter', 'ksp' => 'application/vnd.kde.kspread', 'ktr' => 'application/vnd.kahootz', 'ktx' => 'image/ktx', 'ktz' => 'application/vnd.kahootz', 'kwd' => 'application/vnd.kde.kword', 'kwt' => 'application/vnd.kde.kword', 'lasxml' => 'application/vnd.las.las+xml', 'latex' => 'application/x-latex', 'lbd' => 'application/vnd.llamagraphics.life-balance.desktop', 'lbe' => 'application/vnd.llamagraphics.life-balance.exchange+xml', 'les' => 'application/vnd.hhe.lesson-player', 'lha' => 'application/octet-stream', 'link66' => 'application/vnd.route66.link66+xml', 'list' => 'text/plain', 'list3820' => 'application/vnd.ibm.modcap', 'listafp' => 'application/vnd.ibm.modcap', 'log' => 'text/plain', 'lostxml' => 'application/lost+xml', 'lrf' => 'application/octet-stream', 'lrm' => 'application/vnd.ms-lrm', 'ltf' => 'application/vnd.frogans.ltf', 'lvp' => 'audio/vnd.lucent.voice', 'lwp' => 'application/vnd.lotus-wordpro', 'lzh' => 'application/octet-stream', 'm13' => 'application/x-msmediaview', 'm14' => 'application/x-msmediaview', 'm1v' => 'video/mpeg', 'm21' => 'application/mp21', 'm2a' => 'audio/mpeg', 'm2v' => 'video/mpeg', 'm3a' => 'audio/mpeg', 'm3u' => 'audio/x-mpegurl', 'm3u8' => 'application/vnd.apple.mpegurl', 'm4a' => 'audio/mp4', 'm4u' => 'video/vnd.mpegurl', 'm4v' => 'video/mp4', 'ma' => 'application/mathematica', 'mads' => 'application/mads+xml', 'mag' => 'application/vnd.ecowin.chart', 'maker' => 'application/vnd.framemaker', 'man' => 'text/troff', 'mathml' => 'application/mathml+xml', 'mb' => 'application/mathematica', 'mbk' => 'application/vnd.mobius.mbk', 'mbox' => 'application/mbox', 'mc1' => 'application/vnd.medcalcdata', 'mcd' => 'application/vnd.mcd', 'mcurl' => 'text/vnd.curl.mcurl', 'mdb' => 'application/x-msaccess', 'mdi' => 'image/vnd.ms-modi', 'me' => 'text/troff', 'mesh' => 'model/mesh', 'meta4' => 'application/metalink4+xml', 'mets' => 'application/mets+xml', 'mfm' => 'application/vnd.mfmp', 'mgp' => 'application/vnd.osgeo.mapguide.package', 'mgz' => 'application/vnd.proteus.magazine', 'mid' => 'audio/midi', 'midi' => 'audio/midi', 'mif' => 'application/vnd.mif', 'mime' => 'message/rfc822', 'mj2' => 'video/mj2', 'mjp2' => 'video/mj2', 'mlp' => 'application/vnd.dolby.mlp', 'mmd' => 'application/vnd.chipnuts.karaoke-mmd', 'mmf' => 'application/vnd.smaf', 'mmr' => 'image/vnd.fujixerox.edmics-mmr', 'mny' => 'application/x-msmoney', 'mobi' => 'application/x-mobipocket-ebook', 'mods' => 'application/mods+xml', 'mov' => 'video/quicktime', 'movie' => 'video/x-sgi-movie', 'mp2' => 'audio/mpeg', 'mp21' => 'application/mp21', 'mp2a' => 'audio/mpeg', 'mp3' => 'audio/mpeg', 'mp4' => 'video/mp4', 'mp4a' => 'audio/mp4', 'mp4s' => 'application/mp4', 'mp4v' => 'video/mp4', 'mpc' => 'application/vnd.mophun.certificate', 'mpe' => 'video/mpeg', 'mpeg' => 'video/mpeg', 'mpg' => 'video/mpeg', 'mpg4' => 'video/mp4', 'mpga' => 'audio/mpeg', 'mpkg' => 'application/vnd.apple.installer+xml', 'mpm' => 'application/vnd.blueice.multipass', 'mpn' => 'application/vnd.mophun.application', 'mpp' => 'application/vnd.ms-project', 'mpt' => 'application/vnd.ms-project', 'mpy' => 'application/vnd.ibm.minipay', 'mqy' => 'application/vnd.mobius.mqy', 'mrc' => 'application/marc', 'mrcx' => 'application/marcxml+xml', 'ms' => 'text/troff', 'mscml' => 'application/mediaservercontrol+xml', 'mseed' => 'application/vnd.fdsn.mseed', 'mseq' => 'application/vnd.mseq', 'msf' => 'application/vnd.epson.msf', 'msh' => 'model/mesh', 'msi' => 'application/x-msdownload', 'msl' => 'application/vnd.mobius.msl', 'msty' => 'application/vnd.muvee.style', 'mts' => 'model/vnd.mts', 'mus' => 'application/vnd.musician', 'musicxml' => 'application/vnd.recordare.musicxml+xml', 'mvb' => 'application/x-msmediaview', 'mwf' => 'application/vnd.mfer', 'mxf' => 'application/mxf', 'mxl' => 'application/vnd.recordare.musicxml', 'mxml' => 'application/xv+xml', 'mxs' => 'application/vnd.triscape.mxs', 'mxu' => 'video/vnd.mpegurl', 'n-gage' => 'application/vnd.nokia.n-gage.symbian.install', 'n3' => 'text/n3', 'nb' => 'application/mathematica', 'nbp' => 'application/vnd.wolfram.player', 'nc' => 'application/x-netcdf', 'ncx' => 'application/x-dtbncx+xml', 'ngdat' => 'application/vnd.nokia.n-gage.data', 'nlu' => 'application/vnd.neurolanguage.nlu', 'nml' => 'application/vnd.enliven', 'nnd' => 'application/vnd.noblenet-directory', 'nns' => 'application/vnd.noblenet-sealer', 'nnw' => 'application/vnd.noblenet-web', 'npx' => 'image/vnd.net-fpx', 'nsf' => 'application/vnd.lotus-notes', 'oa2' => 'application/vnd.fujitsu.oasys2', 'oa3' => 'application/vnd.fujitsu.oasys3', 'oas' => 'application/vnd.fujitsu.oasys', 'obd' => 'application/x-msbinder', 'oda' => 'application/oda', 'odb' => 'application/vnd.oasis.opendocument.database', 'odc' => 'application/vnd.oasis.opendocument.chart', 'odf' => 'application/vnd.oasis.opendocument.formula', 'odft' => 'application/vnd.oasis.opendocument.formula-template', 'odg' => 'application/vnd.oasis.opendocument.graphics', 'odi' => 'application/vnd.oasis.opendocument.image', 'odm' => 'application/vnd.oasis.opendocument.text-master', 'odp' => 'application/vnd.oasis.opendocument.presentation', 'ods' => 'application/vnd.oasis.opendocument.spreadsheet', 'odt' => 'application/vnd.oasis.opendocument.text', 'oga' => 'audio/ogg', 'ogg' => 'audio/ogg', 'ogv' => 'video/ogg', 'ogx' => 'application/ogg', 'onepkg' => 'application/onenote', 'onetmp' => 'application/onenote', 'onetoc' => 'application/onenote', 'onetoc2' => 'application/onenote', 'opf' => 'application/oebps-package+xml', 'oprc' => 'application/vnd.palm', 'org' => 'application/vnd.lotus-organizer', 'osf' => 'application/vnd.yamaha.openscoreformat', 'osfpvg' => 'application/vnd.yamaha.openscoreformat.osfpvg+xml', 'otc' => 'application/vnd.oasis.opendocument.chart-template', 'otf' => 'application/x-font-otf', 'otg' => 'application/vnd.oasis.opendocument.graphics-template', 'oth' => 'application/vnd.oasis.opendocument.text-web', 'oti' => 'application/vnd.oasis.opendocument.image-template', 'otp' => 'application/vnd.oasis.opendocument.presentation-template', 'ots' => 'application/vnd.oasis.opendocument.spreadsheet-template', 'ott' => 'application/vnd.oasis.opendocument.text-template', 'oxt' => 'application/vnd.openofficeorg.extension', 'p' => 'text/x-pascal', 'p10' => 'application/pkcs10', 'p12' => 'application/x-pkcs12', 'p7b' => 'application/x-pkcs7-certificates', 'p7c' => 'application/pkcs7-mime', 'p7m' => 'application/pkcs7-mime', 'p7r' => 'application/x-pkcs7-certreqresp', 'p7s' => 'application/pkcs7-signature', 'p8' => 'application/pkcs8', 'pas' => 'text/x-pascal', 'paw' => 'application/vnd.pawaafile', 'pbd' => 'application/vnd.powerbuilder6', 'pbm' => 'image/x-portable-bitmap', 'pcf' => 'application/x-font-pcf', 'pcl' => 'application/vnd.hp-pcl', 'pclxl' => 'application/vnd.hp-pclxl', 'pct' => 'image/x-pict', 'pcurl' => 'application/vnd.curl.pcurl', 'pcx' => 'image/x-pcx', 'pdb' => 'application/vnd.palm', 'pdf' => 'application/pdf', 'pfa' => 'application/x-font-type1', 'pfb' => 'application/x-font-type1', 'pfm' => 'application/x-font-type1', 'pfr' => 'application/font-tdpfr', 'pfx' => 'application/x-pkcs12', 'pgm' => 'image/x-portable-graymap', 'pgn' => 'application/x-chess-pgn', 'pgp' => 'application/pgp-encrypted', 'php' => 'text/x-php', 'phps' => 'application/x-httpd-phps', 'pic' => 'image/x-pict', 'pkg' => 'application/octet-stream', 'pki' => 'application/pkixcmp', 'pkipath' => 'application/pkix-pkipath', 'plb' => 'application/vnd.3gpp.pic-bw-large', 'plc' => 'application/vnd.mobius.plc', 'plf' => 'application/vnd.pocketlearn', 'pls' => 'application/pls+xml', 'pml' => 'application/vnd.ctc-posml', 'png' => 'image/png', 'pnm' => 'image/x-portable-anymap', 'portpkg' => 'application/vnd.macports.portpkg', 'pot' => 'application/vnd.ms-powerpoint', 'potm' => 'application/vnd.ms-powerpoint.template.macroenabled.12', 'potx' => 'application/vnd.openxmlformats-officedocument.presentationml.template', 'ppam' => 'application/vnd.ms-powerpoint.addin.macroenabled.12', 'ppd' => 'application/vnd.cups-ppd', 'ppm' => 'image/x-portable-pixmap', 'pps' => 'application/vnd.ms-powerpoint', 'ppsm' => 'application/vnd.ms-powerpoint.slideshow.macroenabled.12', 'ppsx' => 'application/vnd.openxmlformats-officedocument.presentationml.slideshow', 'ppt' => 'application/vnd.ms-powerpoint', 'pptm' => 'application/vnd.ms-powerpoint.presentation.macroenabled.12', 'pptx' => 'application/vnd.openxmlformats-officedocument.presentationml.presentation', 'pqa' => 'application/vnd.palm', 'prc' => 'application/x-mobipocket-ebook', 'pre' => 'application/vnd.lotus-freelance', 'prf' => 'application/pics-rules', 'ps' => 'application/postscript', 'psb' => 'application/vnd.3gpp.pic-bw-small', 'psd' => 'image/vnd.adobe.photoshop', 'psf' => 'application/x-font-linux-psf', 'pskcxml' => 'application/pskc+xml', 'ptid' => 'application/vnd.pvi.ptid1', 'pub' => 'application/x-mspublisher', 'pvb' => 'application/vnd.3gpp.pic-bw-var', 'pwn' => 'application/vnd.3m.post-it-notes', 'pya' => 'audio/vnd.ms-playready.media.pya', 'pyv' => 'video/vnd.ms-playready.media.pyv', 'qam' => 'application/vnd.epson.quickanime', 'qbo' => 'application/vnd.intu.qbo', 'qfx' => 'application/vnd.intu.qfx', 'qps' => 'application/vnd.publishare-delta-tree', 'qt' => 'video/quicktime', 'qwd' => 'application/vnd.quark.quarkxpress', 'qwt' => 'application/vnd.quark.quarkxpress', 'qxb' => 'application/vnd.quark.quarkxpress', 'qxd' => 'application/vnd.quark.quarkxpress', 'qxl' => 'application/vnd.quark.quarkxpress', 'qxt' => 'application/vnd.quark.quarkxpress', 'ra' => 'audio/x-pn-realaudio', 'ram' => 'audio/x-pn-realaudio', 'rar' => 'application/x-rar-compressed', 'ras' => 'image/x-cmu-raster', 'rb' => 'text/plain', 'rcprofile' => 'application/vnd.ipunplugged.rcprofile', 'rdf' => 'application/rdf+xml', 'rdz' => 'application/vnd.data-vision.rdz', 'rep' => 'application/vnd.businessobjects', 'res' => 'application/x-dtbresource+xml', 'resx' => 'text/xml', 'rgb' => 'image/x-rgb', 'rif' => 'application/reginfo+xml', 'rip' => 'audio/vnd.rip', 'rl' => 'application/resource-lists+xml', 'rlc' => 'image/vnd.fujixerox.edmics-rlc', 'rld' => 'application/resource-lists-diff+xml', 'rm' => 'application/vnd.rn-realmedia', 'rmi' => 'audio/midi', 'rmp' => 'audio/x-pn-realaudio-plugin', 'rms' => 'application/vnd.jcp.javame.midlet-rms', 'rnc' => 'application/relax-ng-compact-syntax', 'roff' => 'text/troff', 'rp9' => 'application/vnd.cloanto.rp9', 'rpss' => 'application/vnd.nokia.radio-presets', 'rpst' => 'application/vnd.nokia.radio-preset', 'rq' => 'application/sparql-query', 'rs' => 'application/rls-services+xml', 'rsd' => 'application/rsd+xml', 'rss' => 'application/rss+xml', 'rtf' => 'application/rtf', 'rtx' => 'text/richtext', 's' => 'text/x-asm', 'saf' => 'application/vnd.yamaha.smaf-audio', 'sbml' => 'application/sbml+xml', 'sc' => 'application/vnd.ibm.secure-container', 'scd' => 'application/x-msschedule', 'scm' => 'application/vnd.lotus-screencam', 'scq' => 'application/scvp-cv-request', 'scs' => 'application/scvp-cv-response', 'scurl' => 'text/vnd.curl.scurl', 'sda' => 'application/vnd.stardivision.draw', 'sdc' => 'application/vnd.stardivision.calc', 'sdd' => 'application/vnd.stardivision.impress', 'sdkd' => 'application/vnd.solent.sdkm+xml', 'sdkm' => 'application/vnd.solent.sdkm+xml', 'sdp' => 'application/sdp', 'sdw' => 'application/vnd.stardivision.writer', 'see' => 'application/vnd.seemail', 'seed' => 'application/vnd.fdsn.seed', 'sema' => 'application/vnd.sema', 'semd' => 'application/vnd.semd', 'semf' => 'application/vnd.semf', 'ser' => 'application/java-serialized-object', 'setpay' => 'application/set-payment-initiation', 'setreg' => 'application/set-registration-initiation', 'sfd-hdstx' => 'application/vnd.hydrostatix.sof-data', 'sfs' => 'application/vnd.spotfire.sfs', 'sgl' => 'application/vnd.stardivision.writer-global', 'sgm' => 'text/sgml', 'sgml' => 'text/sgml', 'sh' => 'application/x-sh', 'shar' => 'application/x-shar', 'shf' => 'application/shf+xml', 'sig' => 'application/pgp-signature', 'silo' => 'model/mesh', 'sis' => 'application/vnd.symbian.install', 'sisx' => 'application/vnd.symbian.install', 'sit' => 'application/x-stuffit', 'sitx' => 'application/x-stuffitx', 'skd' => 'application/vnd.koan', 'skm' => 'application/vnd.koan', 'skp' => 'application/vnd.koan', 'skt' => 'application/vnd.koan', 'sldm' => 'application/vnd.ms-powerpoint.slide.macroenabled.12', 'sldx' => 'application/vnd.openxmlformats-officedocument.presentationml.slide', 'slt' => 'application/vnd.epson.salt', 'sm' => 'application/vnd.stepmania.stepchart', 'smf' => 'application/vnd.stardivision.math', 'smi' => 'application/smil+xml', 'smil' => 'application/smil+xml', 'snd' => 'audio/basic', 'snf' => 'application/x-font-snf', 'so' => 'application/octet-stream', 'spc' => 'application/x-pkcs7-certificates', 'spf' => 'application/vnd.yamaha.smaf-phrase', 'spl' => 'application/x-futuresplash', 'spot' => 'text/vnd.in3d.spot', 'spp' => 'application/scvp-vp-response', 'spq' => 'application/scvp-vp-request', 'spx' => 'audio/ogg', 'src' => 'application/x-wais-source', 'sru' => 'application/sru+xml', 'srx' => 'application/sparql-results+xml', 'sse' => 'application/vnd.kodak-descriptor', 'ssf' => 'application/vnd.epson.ssf', 'ssml' => 'application/ssml+xml', 'st' => 'application/vnd.sailingtracker.track', 'stc' => 'application/vnd.sun.xml.calc.template', 'std' => 'application/vnd.sun.xml.draw.template', 'stf' => 'application/vnd.wt.stf', 'sti' => 'application/vnd.sun.xml.impress.template', 'stk' => 'application/hyperstudio', 'stl' => 'application/vnd.ms-pki.stl', 'str' => 'application/vnd.pg.format', 'stw' => 'application/vnd.sun.xml.writer.template', 'sub' => 'image/vnd.dvb.subtitle', 'sus' => 'application/vnd.sus-calendar', 'susp' => 'application/vnd.sus-calendar', 'sv4cpio' => 'application/x-sv4cpio', 'sv4crc' => 'application/x-sv4crc', 'svc' => 'application/vnd.dvb.service', 'svd' => 'application/vnd.svd', 'svg' => 'image/svg+xml', 'svgz' => 'image/svg+xml', 'swa' => 'application/x-director', 'swf' => 'application/x-shockwave-flash', 'swi' => 'application/vnd.aristanetworks.swi', 'sxc' => 'application/vnd.sun.xml.calc', 'sxd' => 'application/vnd.sun.xml.draw', 'sxg' => 'application/vnd.sun.xml.writer.global', 'sxi' => 'application/vnd.sun.xml.impress', 'sxm' => 'application/vnd.sun.xml.math', 'sxw' => 'application/vnd.sun.xml.writer', 't' => 'text/troff', 'tao' => 'application/vnd.tao.intent-module-archive', 'tar' => 'application/x-tar', 'tcap' => 'application/vnd.3gpp2.tcap', 'tcl' => 'application/x-tcl', 'teacher' => 'application/vnd.smart.teacher', 'tei' => 'application/tei+xml', 'teicorpus' => 'application/tei+xml', 'tex' => 'application/x-tex', 'texi' => 'application/x-texinfo', 'texinfo' => 'application/x-texinfo', 'text' => 'text/plain', 'tfi' => 'application/thraud+xml', 'tfm' => 'application/x-tex-tfm', 'thmx' => 'application/vnd.ms-officetheme', 'tif' => 'image/tiff', 'tiff' => 'image/tiff', 'tmo' => 'application/vnd.tmobile-livetv', 'torrent' => 'application/x-bittorrent', 'tpl' => 'application/vnd.groove-tool-template', 'tpt' => 'application/vnd.trid.tpt', 'tr' => 'text/troff', 'tra' => 'application/vnd.trueapp', 'trm' => 'application/x-msterminal', 'tsd' => 'application/timestamped-data', 'tsv' => 'text/tab-separated-values', 'ttc' => 'application/x-font-ttf', 'ttf' => 'application/x-font-ttf', 'ttl' => 'text/turtle', 'twd' => 'application/vnd.simtech-mindmapper', 'twds' => 'application/vnd.simtech-mindmapper', 'txd' => 'application/vnd.genomatix.tuxedo', 'txf' => 'application/vnd.mobius.txf', 'txt' => 'text/plain', 'u32' => 'application/x-authorware-bin', 'udeb' => 'application/x-debian-package', 'ufd' => 'application/vnd.ufdl', 'ufdl' => 'application/vnd.ufdl', 'umj' => 'application/vnd.umajin', 'unityweb' => 'application/vnd.unity', 'uoml' => 'application/vnd.uoml+xml', 'uri' => 'text/uri-list', 'uris' => 'text/uri-list', 'urls' => 'text/uri-list', 'ustar' => 'application/x-ustar', 'utz' => 'application/vnd.uiq.theme', 'uu' => 'text/x-uuencode', 'uva' => 'audio/vnd.dece.audio', 'uvd' => 'application/vnd.dece.data', 'uvf' => 'application/vnd.dece.data', 'uvg' => 'image/vnd.dece.graphic', 'uvh' => 'video/vnd.dece.hd', 'uvi' => 'image/vnd.dece.graphic', 'uvm' => 'video/vnd.dece.mobile', 'uvp' => 'video/vnd.dece.pd', 'uvs' => 'video/vnd.dece.sd', 'uvt' => 'application/vnd.dece.ttml+xml', 'uvu' => 'video/vnd.uvvu.mp4', 'uvv' => 'video/vnd.dece.video', 'uvva' => 'audio/vnd.dece.audio', 'uvvd' => 'application/vnd.dece.data', 'uvvf' => 'application/vnd.dece.data', 'uvvg' => 'image/vnd.dece.graphic', 'uvvh' => 'video/vnd.dece.hd', 'uvvi' => 'image/vnd.dece.graphic', 'uvvm' => 'video/vnd.dece.mobile', 'uvvp' => 'video/vnd.dece.pd', 'uvvs' => 'video/vnd.dece.sd', 'uvvt' => 'application/vnd.dece.ttml+xml', 'uvvu' => 'video/vnd.uvvu.mp4', 'uvvv' => 'video/vnd.dece.video', 'uvvx' => 'application/vnd.dece.unspecified', 'uvx' => 'application/vnd.dece.unspecified', 'vcd' => 'application/x-cdlink', 'vcf' => 'text/x-vcard', 'vcg' => 'application/vnd.groove-vcard', 'vcs' => 'text/x-vcalendar', 'vcx' => 'application/vnd.vcx', 'vis' => 'application/vnd.visionary', 'viv' => 'video/vnd.vivo', 'vor' => 'application/vnd.stardivision.writer', 'vox' => 'application/x-authorware-bin', 'vrml' => 'model/vrml', 'vsd' => 'application/vnd.visio', 'vsf' => 'application/vnd.vsf', 'vss' => 'application/vnd.visio', 'vst' => 'application/vnd.visio', 'vsw' => 'application/vnd.visio', 'vtu' => 'model/vnd.vtu', 'vxml' => 'application/voicexml+xml', 'w3d' => 'application/x-director', 'wad' => 'application/x-doom', 'wav' => 'audio/x-wav', 'wax' => 'audio/x-ms-wax', 'wbmp' => 'image/vnd.wap.wbmp', 'wbs' => 'application/vnd.criticaltools.wbs+xml', 'wbxml' => 'application/vnd.wap.wbxml', 'wcm' => 'application/vnd.ms-works', 'wdb' => 'application/vnd.ms-works', 'weba' => 'audio/webm', 'webm' => 'video/webm', 'webp' => 'image/webp', 'wg' => 'application/vnd.pmi.widget', 'wgt' => 'application/widget', 'wks' => 'application/vnd.ms-works', 'wm' => 'video/x-ms-wm', 'wma' => 'audio/x-ms-wma', 'wmd' => 'application/x-ms-wmd', 'wmf' => 'application/x-msmetafile', 'wml' => 'text/vnd.wap.wml', 'wmlc' => 'application/vnd.wap.wmlc', 'wmls' => 'text/vnd.wap.wmlscript', 'wmlsc' => 'application/vnd.wap.wmlscriptc', 'wmv' => 'video/x-ms-wmv', 'wmx' => 'video/x-ms-wmx', 'wmz' => 'application/x-ms-wmz', 'woff' => 'application/x-font-woff', 'wpd' => 'application/vnd.wordperfect', 'wpl' => 'application/vnd.ms-wpl', 'wps' => 'application/vnd.ms-works', 'wqd' => 'application/vnd.wqd', 'wri' => 'application/x-mswrite', 'wrl' => 'model/vrml', 'wsdl' => 'application/wsdl+xml', 'wspolicy' => 'application/wspolicy+xml', 'wtb' => 'application/vnd.webturbo', 'wvx' => 'video/x-ms-wvx', 'x32' => 'application/x-authorware-bin', 'x3d' => 'application/vnd.hzn-3d-crossword', 'xap' => 'application/x-silverlight-app', 'xar' => 'application/vnd.xara', 'xbap' => 'application/x-ms-xbap', 'xbd' => 'application/vnd.fujixerox.docuworks.binder', 'xbm' => 'image/x-xbitmap', 'xdf' => 'application/xcap-diff+xml', 'xdm' => 'application/vnd.syncml.dm+xml', 'xdp' => 'application/vnd.adobe.xdp+xml', 'xdssc' => 'application/dssc+xml', 'xdw' => 'application/vnd.fujixerox.docuworks', 'xenc' => 'application/xenc+xml', 'xer' => 'application/patch-ops-error+xml', 'xfdf' => 'application/vnd.adobe.xfdf', 'xfdl' => 'application/vnd.xfdl', 'xht' => 'application/xhtml+xml', 'xhtml' => 'application/xhtml+xml', 'xhvml' => 'application/xv+xml', 'xif' => 'image/vnd.xiff', 'xla' => 'application/vnd.ms-excel', 'xlam' => 'application/vnd.ms-excel.addin.macroenabled.12', 'xlc' => 'application/vnd.ms-excel', 'xlm' => 'application/vnd.ms-excel', 'xls' => 'application/vnd.ms-excel', 'xlsb' => 'application/vnd.ms-excel.sheet.binary.macroenabled.12', 'xlsm' => 'application/vnd.ms-excel.sheet.macroenabled.12', 'xlsx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', 'xlt' => 'application/vnd.ms-excel', 'xltm' => 'application/vnd.ms-excel.template.macroenabled.12', 'xltx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.template', 'xlw' => 'application/vnd.ms-excel', 'xml' => 'application/xml', 'xo' => 'application/vnd.olpc-sugar', 'xop' => 'application/xop+xml', 'xpi' => 'application/x-xpinstall', 'xpm' => 'image/x-xpixmap', 'xpr' => 'application/vnd.is-xpr', 'xps' => 'application/vnd.ms-xpsdocument', 'xpw' => 'application/vnd.intercon.formnet', 'xpx' => 'application/vnd.intercon.formnet', 'xsl' => 'application/xml', 'xslt' => 'application/xslt+xml', 'xsm' => 'application/vnd.syncml+xml', 'xspf' => 'application/xspf+xml', 'xul' => 'application/vnd.mozilla.xul+xml', 'xvm' => 'application/xv+xml', 'xvml' => 'application/xv+xml', 'xwd' => 'image/x-xwindowdump', 'xyz' => 'chemical/x-xyz', 'yaml' => 'text/yaml', 'yang' => 'application/yang', 'yin' => 'application/yin+xml', 'yml' => 'text/yaml', 'zaz' => 'application/vnd.zzazz.deck+xml', 'zip' => 'application/zip', 'zir' => 'application/vnd.zul', 'zirz' => 'application/vnd.zul', 'zmm' => 'application/vnd.handheld-entertainment+xml' ); /** * Get a singleton instance of the class * * @return self * @codeCoverageIgnore */ public static function getInstance() { if (!self::$instance) { self::$instance = new self(); } return self::$instance; } /** * Get a mimetype value from a file extension * * @param string $extension File extension * * @return string|null * */ public function fromExtension($extension) { $extension = strtolower($extension); return isset($this->mimetypes[$extension]) ? $this->mimetypes[$extension] : null; } /** * Get a mimetype from a filename * * @param string $filename Filename to generate a mimetype from * * @return string|null */ public function fromFilename($filename) { return $this->fromExtension(pathinfo($filename, PATHINFO_EXTENSION)); } } isUrlEncoding()) { return array($query->encodeValue($key) => implode(',', array_map(array($query, 'encodeValue'), $value))); } else { return array($key => implode(',', $value)); } } } isUrlEncoding()) { return array($query->encodeValue($key) => array_map(array($query, 'encodeValue'), $value)); } else { return array($key => $value); } } } $v) { $k = "{$key}[{$k}]"; if (is_array($v)) { $ret = array_merge($ret, self::aggregate($k, $v, $query)); } else { $ret[$query->encodeValue($k)] = $query->encodeValue($v); } } return $ret; } } add($key, $value); $foundDuplicates = true; } elseif ($paramIsPhpStyleArray) { $q[$key] = array($value); } else { $q[$key] = $value; } } else { $q->add($key, self::BLANK); } } // Use the duplicate aggregator if duplicates were found and not using PHP style arrays if ($foundDuplicates && !$foundPhpStyle) { $q->setAggregator(new DuplicateAggregator()); } return $q; } /** * Convert the query string parameters to a query string string * * @return string */ public function __toString() { if (!$this->data) { return ''; } $queryString = ''; foreach ($this->prepareData($this->data) as $name => $value) { foreach ((array) $value as $v) { if ($queryString) { $queryString .= $this->fieldSeparator; } $queryString .= $name; if ($v !== self::BLANK) { $queryString .= $this->valueSeparator . $v; } } } return $queryString; } /** * Get the query string field separator * * @return string */ public function getFieldSeparator() { return $this->fieldSeparator; } /** * Get the query string value separator * * @return string */ public function getValueSeparator() { return $this->valueSeparator; } /** * Returns the type of URL encoding used by the query string * * One of: false, "RFC 3986", or "application/x-www-form-urlencoded" * * @return bool|string */ public function getUrlEncoding() { return $this->urlEncode; } /** * Returns true or false if using URL encoding * * @return bool */ public function isUrlEncoding() { return $this->urlEncode !== false; } /** * Provide a function for combining multi-valued query string parameters into a single or multiple fields * * @param null|QueryAggregatorInterface $aggregator Pass in a QueryAggregatorInterface object to handle converting * deeply nested query string variables into a flattened array. * Pass null to use the default PHP style aggregator. For legacy * reasons, this function accepts a callable that must accepts a * $key, $value, and query object. * @return self * @see \Guzzle\Http\QueryString::aggregateUsingComma() */ public function setAggregator(QueryAggregatorInterface $aggregator = null) { // Use the default aggregator if none was set if (!$aggregator) { if (!self::$defaultAggregator) { self::$defaultAggregator = new PhpAggregator(); } $aggregator = self::$defaultAggregator; } $this->aggregator = $aggregator; return $this; } /** * Set whether or not field names and values should be rawurlencoded * * @param bool|string $encode Set to TRUE to use RFC 3986 encoding (rawurlencode), false to disable encoding, or * form_urlencoding to use application/x-www-form-urlencoded encoding (urlencode) * @return self */ public function useUrlEncoding($encode) { $this->urlEncode = ($encode === true) ? self::RFC_3986 : $encode; return $this; } /** * Set the query string separator * * @param string $separator The query string separator that will separate fields * * @return self */ public function setFieldSeparator($separator) { $this->fieldSeparator = $separator; return $this; } /** * Set the query string value separator * * @param string $separator The query string separator that will separate values from fields * * @return self */ public function setValueSeparator($separator) { $this->valueSeparator = $separator; return $this; } /** * Returns an array of url encoded field names and values * * @return array */ public function urlEncode() { return $this->prepareData($this->data); } /** * URL encodes a value based on the url encoding type of the query string object * * @param string $value Value to encode * * @return string */ public function encodeValue($value) { if ($this->urlEncode == self::RFC_3986) { return rawurlencode($value); } elseif ($this->urlEncode == self::FORM_URLENCODED) { return urlencode($value); } else { return (string) $value; } } /** * Url encode parameter data and convert nested query strings into a flattened hash. * * @param array $data The data to encode * * @return array Returns an array of encoded values and keys */ protected function prepareData(array $data) { // If no aggregator is present then set the default if (!$this->aggregator) { $this->setAggregator(null); } $temp = array(); foreach ($data as $key => $value) { if (is_array($value)) { $temp = array_merge($temp, $this->aggregator->aggregate($key, $value, $this)); } else { $temp[$this->encodeValue($key)] = $this->encodeValue($value); } } return $temp; } } setLimit($limit)->setOffset($offset); } /** * Returns only a subset of the decorated entity body when cast as a string * {@inheritdoc} */ public function __toString() { return substr((string) $this->body, $this->offset, $this->limit) ?: ''; } public function isConsumed() { return (($this->offset + $this->limit) - $this->body->ftell()) <= 0; } /** * Returns the Content-Length of the limited subset of data * {@inheritdoc} */ public function getContentLength() { $length = $this->body->getContentLength(); return $length === false ? $this->limit : min($this->limit, min($length, $this->offset + $this->limit) - $this->offset); } /** * Allow for a bounded seek on the read limited entity body * {@inheritdoc} */ public function seek($offset, $whence = SEEK_SET) { return $whence === SEEK_SET ? $this->body->seek(max($this->offset, min($this->offset + $this->limit, $offset))) : false; } /** * Set the offset to start limiting from * * @param int $offset Offset to seek to and begin byte limiting from * * @return self */ public function setOffset($offset) { $this->body->seek($offset); $this->offset = $offset; return $this; } /** * Set the limit of bytes that the decorator allows to be read from the stream * * @param int $limit Total number of bytes to allow to be read from the stream * * @return self */ public function setLimit($limit) { $this->limit = $limit; return $this; } public function read($length) { // Check if the current position is less than the total allowed bytes + original offset $remaining = ($this->offset + $this->limit) - $this->body->ftell(); if ($remaining > 0) { // Only return the amount of requested data, ensuring that the byte limit is not exceeded return $this->body->read(min($remaining, $length)); } else { return false; } } } array('onRequestSent', 100), 'request.clone' => 'cleanupRequest', 'request.before_send' => 'cleanupRequest' ); } /** * Clean up the parameters of a request when it is cloned * * @param Event $event Event emitted */ public function cleanupRequest(Event $event) { $params = $event['request']->getParams(); unset($params[self::REDIRECT_COUNT]); unset($params[self::PARENT_REQUEST]); } /** * Called when a request receives a redirect response * * @param Event $event Event emitted */ public function onRequestSent(Event $event) { $response = $event['response']; $request = $event['request']; // Only act on redirect requests with Location headers if (!$response || $request->getParams()->get(self::DISABLE)) { return; } // Trace the original request based on parameter history $original = $this->getOriginalRequest($request); // Terminating condition to set the effective response on the original request if (!$response->isRedirect() || !$response->hasHeader('Location')) { if ($request !== $original) { // This is a terminating redirect response, so set it on the original request $response->getParams()->set(self::REDIRECT_COUNT, $original->getParams()->get(self::REDIRECT_COUNT)); $original->setResponse($response); $response->setEffectiveUrl($request->getUrl()); } return; } $this->sendRedirectRequest($original, $request, $response); } /** * Get the original request that initiated a series of redirects * * @param RequestInterface $request Request to get the original request from * * @return RequestInterface */ protected function getOriginalRequest(RequestInterface $request) { $original = $request; // The number of redirects is held on the original request, so determine which request that is while ($parent = $original->getParams()->get(self::PARENT_REQUEST)) { $original = $parent; } return $original; } /** * Create a redirect request for a specific request object * * Takes into account strict RFC compliant redirection (e.g. redirect POST with POST) vs doing what most clients do * (e.g. redirect POST with GET). * * @param RequestInterface $request Request being redirected * @param RequestInterface $original Original request * @param int $statusCode Status code of the redirect * @param string $location Location header of the redirect * * @return RequestInterface Returns a new redirect request * @throws CouldNotRewindStreamException If the body needs to be rewound but cannot */ protected function createRedirectRequest( RequestInterface $request, $statusCode, $location, RequestInterface $original ) { $redirectRequest = null; $strict = $original->getParams()->get(self::STRICT_REDIRECTS); // Switch method to GET for 303 redirects. 301 and 302 redirects also switch to GET unless we are forcing RFC // compliance to emulate what most browsers do. NOTE: IE only switches methods on 301/302 when coming from a POST. if ($request instanceof EntityEnclosingRequestInterface && ($statusCode == 303 || (!$strict && $statusCode <= 302))) { $redirectRequest = RequestFactory::getInstance()->cloneRequestWithMethod($request, 'GET'); } else { $redirectRequest = clone $request; } $redirectRequest->setIsRedirect(true); // Always use the same response body when redirecting $redirectRequest->setResponseBody($request->getResponseBody()); $location = Url::factory($location); // If the location is not absolute, then combine it with the original URL if (!$location->isAbsolute()) { $originalUrl = $redirectRequest->getUrl(true); // Remove query string parameters and just take what is present on the redirect Location header $originalUrl->getQuery()->clear(); $location = $originalUrl->combine((string) $location, true); } $redirectRequest->setUrl($location); // Add the parent request to the request before it sends (make sure it's before the onRequestClone event too) $redirectRequest->getEventDispatcher()->addListener( 'request.before_send', $func = function ($e) use (&$func, $request, $redirectRequest) { $redirectRequest->getEventDispatcher()->removeListener('request.before_send', $func); $e['request']->getParams()->set(RedirectPlugin::PARENT_REQUEST, $request); } ); // Rewind the entity body of the request if needed if ($redirectRequest instanceof EntityEnclosingRequestInterface && $redirectRequest->getBody()) { $body = $redirectRequest->getBody(); // Only rewind the body if some of it has been read already, and throw an exception if the rewind fails if ($body->ftell() && !$body->rewind()) { throw new CouldNotRewindStreamException( 'Unable to rewind the non-seekable entity body of the request after redirecting. cURL probably ' . 'sent part of body before the redirect occurred. Try adding acustom rewind function using on the ' . 'entity body of the request using setRewindFunction().' ); } } return $redirectRequest; } /** * Prepare the request for redirection and enforce the maximum number of allowed redirects per client * * @param RequestInterface $original Original request * @param RequestInterface $request Request to prepare and validate * @param Response $response The current response * * @return RequestInterface */ protected function prepareRedirection(RequestInterface $original, RequestInterface $request, Response $response) { $params = $original->getParams(); // This is a new redirect, so increment the redirect counter $current = $params[self::REDIRECT_COUNT] + 1; $params[self::REDIRECT_COUNT] = $current; // Use a provided maximum value or default to a max redirect count of 5 $max = isset($params[self::MAX_REDIRECTS]) ? $params[self::MAX_REDIRECTS] : $this->defaultMaxRedirects; // Throw an exception if the redirect count is exceeded if ($current > $max) { $this->throwTooManyRedirectsException($original, $max); return false; } else { // Create a redirect request based on the redirect rules set on the request return $this->createRedirectRequest( $request, $response->getStatusCode(), trim($response->getLocation()), $original ); } } /** * Send a redirect request and handle any errors * * @param RequestInterface $original The originating request * @param RequestInterface $request The current request being redirected * @param Response $response The response of the current request * * @throws BadResponseException|\Exception */ protected function sendRedirectRequest(RequestInterface $original, RequestInterface $request, Response $response) { // Validate and create a redirect request based on the original request and current response if ($redirectRequest = $this->prepareRedirection($original, $request, $response)) { try { $redirectRequest->send(); } catch (BadResponseException $e) { $e->getResponse(); if (!$e->getResponse()) { throw $e; } } } } /** * Throw a too many redirects exception for a request * * @param RequestInterface $original Request * @param int $max Max allowed redirects * * @throws TooManyRedirectsException when too many redirects have been issued */ protected function throwTooManyRedirectsException(RequestInterface $original, $max) { $original->getEventDispatcher()->addListener( 'request.complete', $func = function ($e) use (&$func, $original, $max) { $original->getEventDispatcher()->removeListener('request.complete', $func); $str = "{$max} redirects were issued for this request:\n" . $e['request']->getRawHeaders(); throw new TooManyRedirectsException($str); } ); } } ## ## ca-bundle.crt -- Bundle of CA Root Certificates ## ## Certificate data from Mozilla as of: Sat Dec 29 20:03:40 2012 ## ## This is a bundle of X.509 certificates of public Certificate Authorities ## (CA). These were automatically extracted from Mozilla's root certificates ## file (certdata.txt). This file can be found in the mozilla source tree: ## http://mxr.mozilla.org/mozilla/source/security/nss/lib/ckfw/builtins/certdata.txt?raw=1 ## ## It contains the certificates in PEM format and therefore ## can be directly used with curl / libcurl / php_curl, or with ## an Apache+mod_ssl webserver for SSL client authentication. ## Just configure this file as the SSLCACertificateFile. ## # @(#) $RCSfile: certdata.txt,v $ $Revision: 1.87 $ $Date: 2012/12/29 16:32:45 $ GTE CyberTrust Global Root ========================== -----BEGIN CERTIFICATE----- MIICWjCCAcMCAgGlMA0GCSqGSIb3DQEBBAUAMHUxCzAJBgNVBAYTAlVTMRgwFgYDVQQKEw9HVEUg Q29ycG9yYXRpb24xJzAlBgNVBAsTHkdURSBDeWJlclRydXN0IFNvbHV0aW9ucywgSW5jLjEjMCEG A1UEAxMaR1RFIEN5YmVyVHJ1c3QgR2xvYmFsIFJvb3QwHhcNOTgwODEzMDAyOTAwWhcNMTgwODEz MjM1OTAwWjB1MQswCQYDVQQGEwJVUzEYMBYGA1UEChMPR1RFIENvcnBvcmF0aW9uMScwJQYDVQQL Ex5HVEUgQ3liZXJUcnVzdCBTb2x1dGlvbnMsIEluYy4xIzAhBgNVBAMTGkdURSBDeWJlclRydXN0 IEdsb2JhbCBSb290MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCVD6C28FCc6HrHiM3dFw4u sJTQGz0O9pTAipTHBsiQl8i4ZBp6fmw8U+E3KHNgf7KXUwefU/ltWJTSr41tiGeA5u2ylc9yMcql HHK6XALnZELn+aks1joNrI1CqiQBOeacPwGFVw1Yh0X404Wqk2kmhXBIgD8SFcd5tB8FLztimQID AQABMA0GCSqGSIb3DQEBBAUAA4GBAG3rGwnpXtlR22ciYaQqPEh346B8pt5zohQDhT37qw4wxYMW M4ETCJ57NE7fQMh017l93PR2VX2bY1QY6fDq81yx2YtCHrnAlU66+tXifPVoYb+O7AWXX1uw16OF NMQkpw0PlZPvy5TYnh+dXIVtx6quTx8itc2VrbqnzPmrC3p/ -----END CERTIFICATE----- Thawte Server CA ================ -----BEGIN CERTIFICATE----- MIIDEzCCAnygAwIBAgIBATANBgkqhkiG9w0BAQQFADCBxDELMAkGA1UEBhMCWkExFTATBgNVBAgT DFdlc3Rlcm4gQ2FwZTESMBAGA1UEBxMJQ2FwZSBUb3duMR0wGwYDVQQKExRUaGF3dGUgQ29uc3Vs dGluZyBjYzEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjEZMBcGA1UE AxMQVGhhd3RlIFNlcnZlciBDQTEmMCQGCSqGSIb3DQEJARYXc2VydmVyLWNlcnRzQHRoYXd0ZS5j b20wHhcNOTYwODAxMDAwMDAwWhcNMjAxMjMxMjM1OTU5WjCBxDELMAkGA1UEBhMCWkExFTATBgNV BAgTDFdlc3Rlcm4gQ2FwZTESMBAGA1UEBxMJQ2FwZSBUb3duMR0wGwYDVQQKExRUaGF3dGUgQ29u c3VsdGluZyBjYzEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjEZMBcG A1UEAxMQVGhhd3RlIFNlcnZlciBDQTEmMCQGCSqGSIb3DQEJARYXc2VydmVyLWNlcnRzQHRoYXd0 ZS5jb20wgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBANOkUG7I/1Zr5s9dtuoMaHVHoqrC2oQl /Kj0R1HahbUgdJSGHg91yekIYfUGbTBuFRkC6VLAYttNmZ7iagxEOM3+vuNkCXDF/rFrKbYvScg7 1CcEJRCXL+eQbcAoQpnXTEPew/UhbVSfXcNY4cDk2VuwuNy0e982OsK1ZiIS1ocNAgMBAAGjEzAR MA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEEBQADgYEAB/pMaVz7lcxG7oWDTSEwjsrZqG9J GubaUeNgcGyEYRGhGshIPllDfU+VPaGLtwtimHp1it2ITk6eQNuozDJ0uW8NxuOzRAvZim+aKZuZ GCg70eNAKJpaPNW15yAbi8qkq43pUdniTCxZqdq5snUb9kLy78fyGPmJvKP/iiMucEc= -----END CERTIFICATE----- Thawte Premium Server CA ======================== -----BEGIN CERTIFICATE----- MIIDJzCCApCgAwIBAgIBATANBgkqhkiG9w0BAQQFADCBzjELMAkGA1UEBhMCWkExFTATBgNVBAgT DFdlc3Rlcm4gQ2FwZTESMBAGA1UEBxMJQ2FwZSBUb3duMR0wGwYDVQQKExRUaGF3dGUgQ29uc3Vs dGluZyBjYzEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjEhMB8GA1UE AxMYVGhhd3RlIFByZW1pdW0gU2VydmVyIENBMSgwJgYJKoZIhvcNAQkBFhlwcmVtaXVtLXNlcnZl ckB0aGF3dGUuY29tMB4XDTk2MDgwMTAwMDAwMFoXDTIwMTIzMTIzNTk1OVowgc4xCzAJBgNVBAYT AlpBMRUwEwYDVQQIEwxXZXN0ZXJuIENhcGUxEjAQBgNVBAcTCUNhcGUgVG93bjEdMBsGA1UEChMU VGhhd3RlIENvbnN1bHRpbmcgY2MxKDAmBgNVBAsTH0NlcnRpZmljYXRpb24gU2VydmljZXMgRGl2 aXNpb24xITAfBgNVBAMTGFRoYXd0ZSBQcmVtaXVtIFNlcnZlciBDQTEoMCYGCSqGSIb3DQEJARYZ cHJlbWl1bS1zZXJ2ZXJAdGhhd3RlLmNvbTCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEA0jY2 aovXwlue2oFBYo847kkEVdbQ7xwblRZH7xhINTpS9CtqBo87L+pW46+GjZ4X9560ZXUCTe/LCaIh Udib0GfQug2SBhRz1JPLlyoAnFxODLz6FVL88kRu2hFKbgifLy3j+ao6hnO2RlNYyIkFvYMRuHM/ qgeN9EJN50CdHDcCAwEAAaMTMBEwDwYDVR0TAQH/BAUwAwEB/zANBgkqhkiG9w0BAQQFAAOBgQAm SCwWwlj66BZ0DKqqX1Q/8tfJeGBeXm43YyJ3Nn6yF8Q0ufUIhfzJATj/Tb7yFkJD57taRvvBxhEf 8UqwKEbJw8RCfbz6q1lu1bdRiBHjpIUZa4JMpAwSremkrj/xw0llmozFyD4lt5SZu5IycQfwhl7t UCemDaYj+bvLpgcUQg== -----END CERTIFICATE----- Equifax Secure CA ================= -----BEGIN CERTIFICATE----- MIIDIDCCAomgAwIBAgIENd70zzANBgkqhkiG9w0BAQUFADBOMQswCQYDVQQGEwJVUzEQMA4GA1UE ChMHRXF1aWZheDEtMCsGA1UECxMkRXF1aWZheCBTZWN1cmUgQ2VydGlmaWNhdGUgQXV0aG9yaXR5 MB4XDTk4MDgyMjE2NDE1MVoXDTE4MDgyMjE2NDE1MVowTjELMAkGA1UEBhMCVVMxEDAOBgNVBAoT B0VxdWlmYXgxLTArBgNVBAsTJEVxdWlmYXggU2VjdXJlIENlcnRpZmljYXRlIEF1dGhvcml0eTCB nzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAwV2xWGcIYu6gmi0fCG2RFGiYCh7+2gRvE4RiIcPR fM6fBeC4AfBONOziipUEZKzxa1NfBbPLZ4C/QgKO/t0BCezhABRP/PvwDN1Dulsr4R+AcJkVV5MW 8Q+XarfCaCMczE1ZMKxRHjuvK9buY0V7xdlfUNLjUA86iOe/FP3gx7kCAwEAAaOCAQkwggEFMHAG A1UdHwRpMGcwZaBjoGGkXzBdMQswCQYDVQQGEwJVUzEQMA4GA1UEChMHRXF1aWZheDEtMCsGA1UE CxMkRXF1aWZheCBTZWN1cmUgQ2VydGlmaWNhdGUgQXV0aG9yaXR5MQ0wCwYDVQQDEwRDUkwxMBoG A1UdEAQTMBGBDzIwMTgwODIyMTY0MTUxWjALBgNVHQ8EBAMCAQYwHwYDVR0jBBgwFoAUSOZo+SvS spXXR9gjIBBPM5iQn9QwHQYDVR0OBBYEFEjmaPkr0rKV10fYIyAQTzOYkJ/UMAwGA1UdEwQFMAMB Af8wGgYJKoZIhvZ9B0EABA0wCxsFVjMuMGMDAgbAMA0GCSqGSIb3DQEBBQUAA4GBAFjOKer89961 zgK5F7WF0bnj4JXMJTENAKaSbn+2kmOeUJXRmm/kEd5jhW6Y7qj/WsjTVbJmcVfewCHrPSqnI0kB BIZCe/zuf6IWUrVnZ9NA2zsmWLIodz2uFHdh1voqZiegDfqnc1zqcPGUIWVEX/r87yloqaKHee95 70+sB3c4 -----END CERTIFICATE----- Digital Signature Trust Co. Global CA 1 ======================================= -----BEGIN CERTIFICATE----- MIIDKTCCApKgAwIBAgIENnAVljANBgkqhkiG9w0BAQUFADBGMQswCQYDVQQGEwJVUzEkMCIGA1UE ChMbRGlnaXRhbCBTaWduYXR1cmUgVHJ1c3QgQ28uMREwDwYDVQQLEwhEU1RDQSBFMTAeFw05ODEy MTAxODEwMjNaFw0xODEyMTAxODQwMjNaMEYxCzAJBgNVBAYTAlVTMSQwIgYDVQQKExtEaWdpdGFs IFNpZ25hdHVyZSBUcnVzdCBDby4xETAPBgNVBAsTCERTVENBIEUxMIGdMA0GCSqGSIb3DQEBAQUA A4GLADCBhwKBgQCgbIGpzzQeJN3+hijM3oMv+V7UQtLodGBmE5gGHKlREmlvMVW5SXIACH7TpWJE NySZj9mDSI+ZbZUTu0M7LklOiDfBu1h//uG9+LthzfNHwJmm8fOR6Hh8AMthyUQncWlVSn5JTe2i o74CTADKAqjuAQIxZA9SLRN0dja1erQtcQIBA6OCASQwggEgMBEGCWCGSAGG+EIBAQQEAwIABzBo BgNVHR8EYTBfMF2gW6BZpFcwVTELMAkGA1UEBhMCVVMxJDAiBgNVBAoTG0RpZ2l0YWwgU2lnbmF0 dXJlIFRydXN0IENvLjERMA8GA1UECxMIRFNUQ0EgRTExDTALBgNVBAMTBENSTDEwKwYDVR0QBCQw IoAPMTk5ODEyMTAxODEwMjNagQ8yMDE4MTIxMDE4MTAyM1owCwYDVR0PBAQDAgEGMB8GA1UdIwQY MBaAFGp5fpFpRhgTCgJ3pVlbYJglDqL4MB0GA1UdDgQWBBRqeX6RaUYYEwoCd6VZW2CYJQ6i+DAM BgNVHRMEBTADAQH/MBkGCSqGSIb2fQdBAAQMMAobBFY0LjADAgSQMA0GCSqGSIb3DQEBBQUAA4GB ACIS2Hod3IEGtgllsofIH160L+nEHvI8wbsEkBFKg05+k7lNQseSJqBcNJo4cvj9axY+IO6CizEq kzaFI4iKPANo08kJD038bKTaKHKTDomAsH3+gG9lbRgzl4vCa4nuYD3Im+9/KzJic5PLPON74nZ4 RbyhkwS7hp86W0N6w4pl -----END CERTIFICATE----- Digital Signature Trust Co. Global CA 3 ======================================= -----BEGIN CERTIFICATE----- MIIDKTCCApKgAwIBAgIENm7TzjANBgkqhkiG9w0BAQUFADBGMQswCQYDVQQGEwJVUzEkMCIGA1UE ChMbRGlnaXRhbCBTaWduYXR1cmUgVHJ1c3QgQ28uMREwDwYDVQQLEwhEU1RDQSBFMjAeFw05ODEy MDkxOTE3MjZaFw0xODEyMDkxOTQ3MjZaMEYxCzAJBgNVBAYTAlVTMSQwIgYDVQQKExtEaWdpdGFs IFNpZ25hdHVyZSBUcnVzdCBDby4xETAPBgNVBAsTCERTVENBIEUyMIGdMA0GCSqGSIb3DQEBAQUA A4GLADCBhwKBgQC/k48Xku8zExjrEH9OFr//Bo8qhbxe+SSmJIi2A7fBw18DW9Fvrn5C6mYjuGOD VvsoLeE4i7TuqAHhzhy2iCoiRoX7n6dwqUcUP87eZfCocfdPJmyMvMa1795JJ/9IKn3oTQPMx7JS xhcxEzu1TdvIxPbDDyQq2gyd55FbgM2UnQIBA6OCASQwggEgMBEGCWCGSAGG+EIBAQQEAwIABzBo BgNVHR8EYTBfMF2gW6BZpFcwVTELMAkGA1UEBhMCVVMxJDAiBgNVBAoTG0RpZ2l0YWwgU2lnbmF0 dXJlIFRydXN0IENvLjERMA8GA1UECxMIRFNUQ0EgRTIxDTALBgNVBAMTBENSTDEwKwYDVR0QBCQw IoAPMTk5ODEyMDkxOTE3MjZagQ8yMDE4MTIwOTE5MTcyNlowCwYDVR0PBAQDAgEGMB8GA1UdIwQY MBaAFB6CTShlgDzJQW6sNS5ay97u+DlbMB0GA1UdDgQWBBQegk0oZYA8yUFurDUuWsve7vg5WzAM BgNVHRMEBTADAQH/MBkGCSqGSIb2fQdBAAQMMAobBFY0LjADAgSQMA0GCSqGSIb3DQEBBQUAA4GB AEeNg61i8tuwnkUiBbmi1gMOOHLnnvx75pO2mqWilMg0HZHRxdf0CiUPPXiBng+xZ8SQTGPdXqfi up/1902lMXucKS1M/mQ+7LZT/uqb7YLbdHVLB3luHtgZg3Pe9T7Qtd7nS2h9Qy4qIOF+oHhEngj1 mPnHfxsb1gYgAlihw6ID -----END CERTIFICATE----- Verisign Class 3 Public Primary Certification Authority ======================================================= -----BEGIN CERTIFICATE----- MIICPDCCAaUCEHC65B0Q2Sk0tjjKewPMur8wDQYJKoZIhvcNAQECBQAwXzELMAkGA1UEBhMCVVMx FzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFzcyAzIFB1YmxpYyBQcmltYXJ5 IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTk2MDEyOTAwMDAwMFoXDTI4MDgwMTIzNTk1OVow XzELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFzcyAz IFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIGfMA0GCSqGSIb3DQEBAQUA A4GNADCBiQKBgQDJXFme8huKARS0EN8EQNvjV69qRUCPhAwL0TPZ2RHP7gJYHyX3KqhEBarsAx94 f56TuZoAqiN91qyFomNFx3InzPRMxnVx0jnvT0Lwdd8KkMaOIG+YD/isI19wKTakyYbnsZogy1Ol hec9vn2a/iRFM9x2Fe0PonFkTGUugWhFpwIDAQABMA0GCSqGSIb3DQEBAgUAA4GBALtMEivPLCYA TxQT3ab7/AoRhIzzKBxnki98tsX63/Dolbwdj2wsqFHMc9ikwFPwTtYmwHYBV4GSXiHx0bH/59Ah WM1pF+NEHJwZRDmJXNycAA9WjQKZ7aKQRUzkuxCkPfAyAw7xzvjoyVGM5mKf5p/AfbdynMk2Omuf Tqj/ZA1k -----END CERTIFICATE----- Verisign Class 3 Public Primary Certification Authority - G2 ============================================================ -----BEGIN CERTIFICATE----- MIIDAjCCAmsCEH3Z/gfPqB63EHln+6eJNMYwDQYJKoZIhvcNAQEFBQAwgcExCzAJBgNVBAYTAlVT MRcwFQYDVQQKEw5WZXJpU2lnbiwgSW5jLjE8MDoGA1UECxMzQ2xhc3MgMyBQdWJsaWMgUHJpbWFy eSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEcyMTowOAYDVQQLEzEoYykgMTk5OCBWZXJpU2ln biwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MR8wHQYDVQQLExZWZXJpU2lnbiBUcnVz dCBOZXR3b3JrMB4XDTk4MDUxODAwMDAwMFoXDTI4MDgwMTIzNTk1OVowgcExCzAJBgNVBAYTAlVT MRcwFQYDVQQKEw5WZXJpU2lnbiwgSW5jLjE8MDoGA1UECxMzQ2xhc3MgMyBQdWJsaWMgUHJpbWFy eSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEcyMTowOAYDVQQLEzEoYykgMTk5OCBWZXJpU2ln biwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MR8wHQYDVQQLExZWZXJpU2lnbiBUcnVz dCBOZXR3b3JrMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDMXtERXVxp0KvTuWpMmR9ZmDCO FoUgRm1HP9SFIIThbbP4pO0M8RcPO/mn+SXXwc+EY/J8Y8+iR/LGWzOOZEAEaMGAuWQcRXfH2G71 lSk8UOg013gfqLptQ5GVj0VXXn7F+8qkBOvqlzdUMG+7AUcyM83cV5tkaWH4mx0ciU9cZwIDAQAB MA0GCSqGSIb3DQEBBQUAA4GBAFFNzb5cy5gZnBWyATl4Lk0PZ3BwmcYQWpSkU01UbSuvDV1Ai2TT 1+7eVmGSX6bEHRBhNtMsJzzoKQm5EWR0zLVznxxIqbxhAe7iF6YM40AIOw7n60RzKprxaZLvcRTD Oaxxp5EJb+RxBrO6WVcmeQD2+A2iMzAo1KpYoJ2daZH9 -----END CERTIFICATE----- GlobalSign Root CA ================== -----BEGIN CERTIFICATE----- MIIDdTCCAl2gAwIBAgILBAAAAAABFUtaw5QwDQYJKoZIhvcNAQEFBQAwVzELMAkGA1UEBhMCQkUx GTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYtc2ExEDAOBgNVBAsTB1Jvb3QgQ0ExGzAZBgNVBAMTEkds b2JhbFNpZ24gUm9vdCBDQTAeFw05ODA5MDExMjAwMDBaFw0yODAxMjgxMjAwMDBaMFcxCzAJBgNV BAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRAwDgYDVQQLEwdSb290IENBMRswGQYD VQQDExJHbG9iYWxTaWduIFJvb3QgQ0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDa DuaZjc6j40+Kfvvxi4Mla+pIH/EqsLmVEQS98GPR4mdmzxzdzxtIK+6NiY6arymAZavpxy0Sy6sc THAHoT0KMM0VjU/43dSMUBUc71DuxC73/OlS8pF94G3VNTCOXkNz8kHp1Wrjsok6Vjk4bwY8iGlb Kk3Fp1S4bInMm/k8yuX9ifUSPJJ4ltbcdG6TRGHRjcdGsnUOhugZitVtbNV4FpWi6cgKOOvyJBNP c1STE4U6G7weNLWLBYy5d4ux2x8gkasJU26Qzns3dLlwR5EiUWMWea6xrkEmCMgZK9FGqkjWZCrX gzT/LCrBbBlDSgeF59N89iFo7+ryUp9/k5DPAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV HRMBAf8EBTADAQH/MB0GA1UdDgQWBBRge2YaRQ2XyolQL30EzTSo//z9SzANBgkqhkiG9w0BAQUF AAOCAQEA1nPnfE920I2/7LqivjTFKDK1fPxsnCwrvQmeU79rXqoRSLblCKOzyj1hTdNGCbM+w6Dj Y1Ub8rrvrTnhQ7k4o+YviiY776BQVvnGCv04zcQLcFGUl5gE38NflNUVyRRBnMRddWQVDf9VMOyG j/8N7yy5Y0b2qvzfvGn9LhJIZJrglfCm7ymPAbEVtQwdpf5pLGkkeB6zpxxxYu7KyJesF12KwvhH hm4qxFYxldBniYUr+WymXUadDKqC5JlR3XC321Y9YeRq4VzW9v493kHMB65jUr9TU/Qr6cf9tveC X4XSQRjbgbMEHMUfpIBvFSDJ3gyICh3WZlXi/EjJKSZp4A== -----END CERTIFICATE----- GlobalSign Root CA - R2 ======================= -----BEGIN CERTIFICATE----- MIIDujCCAqKgAwIBAgILBAAAAAABD4Ym5g0wDQYJKoZIhvcNAQEFBQAwTDEgMB4GA1UECxMXR2xv YmFsU2lnbiBSb290IENBIC0gUjIxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkdsb2Jh bFNpZ24wHhcNMDYxMjE1MDgwMDAwWhcNMjExMjE1MDgwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxT aWduIFJvb3QgQ0EgLSBSMjETMBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2ln bjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKbPJA6+Lm8omUVCxKs+IVSbC9N/hHD6 ErPLv4dfxn+G07IwXNb9rfF73OX4YJYJkhD10FPe+3t+c4isUoh7SqbKSaZeqKeMWhG8eoLrvozp s6yWJQeXSpkqBy+0Hne/ig+1AnwblrjFuTosvNYSuetZfeLQBoZfXklqtTleiDTsvHgMCJiEbKjN S7SgfQx5TfC4LcshytVsW33hoCmEofnTlEnLJGKRILzdC9XZzPnqJworc5HGnRusyMvo4KD0L5CL TfuwNhv2GXqF4G3yYROIXJ/gkwpRl4pazq+r1feqCapgvdzZX99yqWATXgAByUr6P6TqBwMhAo6C ygPCm48CAwEAAaOBnDCBmTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E FgQUm+IHV2ccHsBqBt5ZtJot39wZhi4wNgYDVR0fBC8wLTAroCmgJ4YlaHR0cDovL2NybC5nbG9i YWxzaWduLm5ldC9yb290LXIyLmNybDAfBgNVHSMEGDAWgBSb4gdXZxwewGoG3lm0mi3f3BmGLjAN BgkqhkiG9w0BAQUFAAOCAQEAmYFThxxol4aR7OBKuEQLq4GsJ0/WwbgcQ3izDJr86iw8bmEbTUsp 9Z8FHSbBuOmDAGJFtqkIk7mpM0sYmsL4h4hO291xNBrBVNpGP+DTKqttVCL1OmLNIG+6KYnX3ZHu 01yiPqFbQfXf5WRDLenVOavSot+3i9DAgBkcRcAtjOj4LaR0VknFBbVPFd5uRHg5h6h+u/N5GJG7 9G+dwfCMNYxdAfvDbbnvRG15RjF+Cv6pgsH/76tuIMRQyV+dTZsXjAzlAcmgQWpzU/qlULRuJQ/7 TBj0/VLZjmmx6BEP3ojY+x1J96relc8geMJgEtslQIxq/H5COEBkEveegeGTLg== -----END CERTIFICATE----- ValiCert Class 1 VA =================== -----BEGIN CERTIFICATE----- MIIC5zCCAlACAQEwDQYJKoZIhvcNAQEFBQAwgbsxJDAiBgNVBAcTG1ZhbGlDZXJ0IFZhbGlkYXRp b24gTmV0d29yazEXMBUGA1UEChMOVmFsaUNlcnQsIEluYy4xNTAzBgNVBAsTLFZhbGlDZXJ0IENs YXNzIDEgUG9saWN5IFZhbGlkYXRpb24gQXV0aG9yaXR5MSEwHwYDVQQDExhodHRwOi8vd3d3LnZh bGljZXJ0LmNvbS8xIDAeBgkqhkiG9w0BCQEWEWluZm9AdmFsaWNlcnQuY29tMB4XDTk5MDYyNTIy MjM0OFoXDTE5MDYyNTIyMjM0OFowgbsxJDAiBgNVBAcTG1ZhbGlDZXJ0IFZhbGlkYXRpb24gTmV0 d29yazEXMBUGA1UEChMOVmFsaUNlcnQsIEluYy4xNTAzBgNVBAsTLFZhbGlDZXJ0IENsYXNzIDEg UG9saWN5IFZhbGlkYXRpb24gQXV0aG9yaXR5MSEwHwYDVQQDExhodHRwOi8vd3d3LnZhbGljZXJ0 LmNvbS8xIDAeBgkqhkiG9w0BCQEWEWluZm9AdmFsaWNlcnQuY29tMIGfMA0GCSqGSIb3DQEBAQUA A4GNADCBiQKBgQDYWYJ6ibiWuqYvaG9YLqdUHAZu9OqNSLwxlBfw8068srg1knaw0KWlAdcAAxIi GQj4/xEjm84H9b9pGib+TunRf50sQB1ZaG6m+FiwnRqP0z/x3BkGgagO4DrdyFNFCQbmD3DD+kCm DuJWBQ8YTfwggtFzVXSNdnKgHZ0dwN0/cQIDAQABMA0GCSqGSIb3DQEBBQUAA4GBAFBoPUn0LBwG lN+VYH+Wexf+T3GtZMjdd9LvWVXoP+iOBSoh8gfStadS/pyxtuJbdxdA6nLWI8sogTLDAHkY7FkX icnGah5xyf23dKUlRWnFSKsZ4UWKJWsZ7uW7EvV/96aNUcPwnXS3qT6gpf+2SQMT2iLM7XGCK5nP Orf1LXLI -----END CERTIFICATE----- ValiCert Class 2 VA =================== -----BEGIN CERTIFICATE----- MIIC5zCCAlACAQEwDQYJKoZIhvcNAQEFBQAwgbsxJDAiBgNVBAcTG1ZhbGlDZXJ0IFZhbGlkYXRp b24gTmV0d29yazEXMBUGA1UEChMOVmFsaUNlcnQsIEluYy4xNTAzBgNVBAsTLFZhbGlDZXJ0IENs YXNzIDIgUG9saWN5IFZhbGlkYXRpb24gQXV0aG9yaXR5MSEwHwYDVQQDExhodHRwOi8vd3d3LnZh bGljZXJ0LmNvbS8xIDAeBgkqhkiG9w0BCQEWEWluZm9AdmFsaWNlcnQuY29tMB4XDTk5MDYyNjAw MTk1NFoXDTE5MDYyNjAwMTk1NFowgbsxJDAiBgNVBAcTG1ZhbGlDZXJ0IFZhbGlkYXRpb24gTmV0 d29yazEXMBUGA1UEChMOVmFsaUNlcnQsIEluYy4xNTAzBgNVBAsTLFZhbGlDZXJ0IENsYXNzIDIg UG9saWN5IFZhbGlkYXRpb24gQXV0aG9yaXR5MSEwHwYDVQQDExhodHRwOi8vd3d3LnZhbGljZXJ0 LmNvbS8xIDAeBgkqhkiG9w0BCQEWEWluZm9AdmFsaWNlcnQuY29tMIGfMA0GCSqGSIb3DQEBAQUA A4GNADCBiQKBgQDOOnHK5avIWZJV16vYdA757tn2VUdZZUcOBVXc65g2PFxTXdMwzzjsvUGJ7SVC CSRrCl6zfN1SLUzm1NZ9WlmpZdRJEy0kTRxQb7XBhVQ7/nHk01xC+YDgkRoKWzk2Z/M/VXwbP7Rf ZHM047QSv4dk+NoS/zcnwbNDu+97bi5p9wIDAQABMA0GCSqGSIb3DQEBBQUAA4GBADt/UG9vUJSZ SWI4OB9L+KXIPqeCgfYrx+jFzug6EILLGACOTb2oWH+heQC1u+mNr0HZDzTuIYEZoDJJKPTEjlbV UjP9UNV+mWwD5MlM/Mtsq2azSiGM5bUMMj4QssxsodyamEwCW/POuZ6lcg5Ktz885hZo+L7tdEy8 W9ViH0Pd -----END CERTIFICATE----- RSA Root Certificate 1 ====================== -----BEGIN CERTIFICATE----- MIIC5zCCAlACAQEwDQYJKoZIhvcNAQEFBQAwgbsxJDAiBgNVBAcTG1ZhbGlDZXJ0IFZhbGlkYXRp b24gTmV0d29yazEXMBUGA1UEChMOVmFsaUNlcnQsIEluYy4xNTAzBgNVBAsTLFZhbGlDZXJ0IENs YXNzIDMgUG9saWN5IFZhbGlkYXRpb24gQXV0aG9yaXR5MSEwHwYDVQQDExhodHRwOi8vd3d3LnZh bGljZXJ0LmNvbS8xIDAeBgkqhkiG9w0BCQEWEWluZm9AdmFsaWNlcnQuY29tMB4XDTk5MDYyNjAw MjIzM1oXDTE5MDYyNjAwMjIzM1owgbsxJDAiBgNVBAcTG1ZhbGlDZXJ0IFZhbGlkYXRpb24gTmV0 d29yazEXMBUGA1UEChMOVmFsaUNlcnQsIEluYy4xNTAzBgNVBAsTLFZhbGlDZXJ0IENsYXNzIDMg UG9saWN5IFZhbGlkYXRpb24gQXV0aG9yaXR5MSEwHwYDVQQDExhodHRwOi8vd3d3LnZhbGljZXJ0 LmNvbS8xIDAeBgkqhkiG9w0BCQEWEWluZm9AdmFsaWNlcnQuY29tMIGfMA0GCSqGSIb3DQEBAQUA A4GNADCBiQKBgQDjmFGWHOjVsQaBalfDcnWTq8+epvzzFlLWLU2fNUSoLgRNB0mKOCn1dzfnt6td 3zZxFJmP3MKS8edgkpfs2Ejcv8ECIMYkpChMMFp2bbFc893enhBxoYjHW5tBbcqwuI4V7q0zK89H BFx1cQqYJJgpp0lZpd34t0NiYfPT4tBVPwIDAQABMA0GCSqGSIb3DQEBBQUAA4GBAFa7AliEZwgs 3x/be0kz9dNnnfS0ChCzycUs4pJqcXgn8nCDQtM+z6lU9PHYkhaM0QTLS6vJn0WuPIqpsHEzXcjF V9+vqDWzf4mH6eglkrh/hXqu1rweN1gqZ8mRzyqBPu3GOd/APhmcGcwTTYJBtYze4D1gCCAPRX5r on+jjBXu -----END CERTIFICATE----- Verisign Class 3 Public Primary Certification Authority - G3 ============================================================ -----BEGIN CERTIFICATE----- MIIEGjCCAwICEQCbfgZJoz5iudXukEhxKe9XMA0GCSqGSIb3DQEBBQUAMIHKMQswCQYDVQQGEwJV UzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRydXN0IE5ldHdv cmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWduLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNl IG9ubHkxRTBDBgNVBAMTPFZlcmlTaWduIENsYXNzIDMgUHVibGljIFByaW1hcnkgQ2VydGlmaWNh dGlvbiBBdXRob3JpdHkgLSBHMzAeFw05OTEwMDEwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMIHKMQsw CQYDVQQGEwJVUzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRy dXN0IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWduLCBJbmMuIC0gRm9yIGF1dGhv cml6ZWQgdXNlIG9ubHkxRTBDBgNVBAMTPFZlcmlTaWduIENsYXNzIDMgUHVibGljIFByaW1hcnkg Q2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBHMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC ggEBAMu6nFL8eB8aHm8bN3O9+MlrlBIwT/A2R/XQkQr1F8ilYcEWQE37imGQ5XYgwREGfassbqb1 EUGO+i2tKmFZpGcmTNDovFJbcCAEWNF6yaRpvIMXZK0Fi7zQWM6NjPXr8EJJC52XJ2cybuGukxUc cLwgTS8Y3pKI6GyFVxEa6X7jJhFUokWWVYPKMIno3Nij7SqAP395ZVc+FSBmCC+Vk7+qRy+oRpfw EuL+wgorUeZ25rdGt+INpsyow0xZVYnm6FNcHOqd8GIWC6fJXwzw3sJ2zq/3avL6QaaiMxTJ5Xpj 055iN9WFZZ4O5lMkdBteHRJTW8cs54NJOxWuimi5V5cCAwEAATANBgkqhkiG9w0BAQUFAAOCAQEA ERSWwauSCPc/L8my/uRan2Te2yFPhpk0djZX3dAVL8WtfxUfN2JzPtTnX84XA9s1+ivbrmAJXx5f j267Cz3qWhMeDGBvtcC1IyIuBwvLqXTLR7sdwdela8wv0kL9Sd2nic9TutoAWii/gt/4uhMdUIaC /Y4wjylGsB49Ndo4YhYYSq3mtlFs3q9i6wHQHiT+eo8SGhJouPtmmRQURVyu565pF4ErWjfJXir0 xuKhXFSbplQAz/DxwceYMBo7Nhbbo27q/a2ywtrvAkcTisDxszGtTxzhT5yvDwyd93gN2PQ1VoDa t20Xj50egWTh/sVFuq1ruQp6Tk9LhO5L8X3dEQ== -----END CERTIFICATE----- Verisign Class 4 Public Primary Certification Authority - G3 ============================================================ -----BEGIN CERTIFICATE----- MIIEGjCCAwICEQDsoKeLbnVqAc/EfMwvlF7XMA0GCSqGSIb3DQEBBQUAMIHKMQswCQYDVQQGEwJV UzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRydXN0IE5ldHdv cmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWduLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNl IG9ubHkxRTBDBgNVBAMTPFZlcmlTaWduIENsYXNzIDQgUHVibGljIFByaW1hcnkgQ2VydGlmaWNh dGlvbiBBdXRob3JpdHkgLSBHMzAeFw05OTEwMDEwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMIHKMQsw CQYDVQQGEwJVUzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRy dXN0IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWduLCBJbmMuIC0gRm9yIGF1dGhv cml6ZWQgdXNlIG9ubHkxRTBDBgNVBAMTPFZlcmlTaWduIENsYXNzIDQgUHVibGljIFByaW1hcnkg Q2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBHMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC ggEBAK3LpRFpxlmr8Y+1GQ9Wzsy1HyDkniYlS+BzZYlZ3tCD5PUPtbut8XzoIfzk6AzufEUiGXaS tBO3IFsJ+mGuqPKljYXCKtbeZjbSmwL0qJJgfJxptI8kHtCGUvYynEFYHiK9zUVilQhu0GbdU6LM 8BDcVHOLBKFGMzNcF0C5nk3T875Vg+ixiY5afJqWIpA7iCXy0lOIAgwLePLmNxdLMEYH5IBtptiW Lugs+BGzOA1mppvqySNb247i8xOOGlktqgLw7KSHZtzBP/XYufTsgsbSPZUd5cBPhMnZo0QoBmrX Razwa2rvTl/4EYIeOGM0ZlDUPpNz+jDDZq3/ky2X7wMCAwEAATANBgkqhkiG9w0BAQUFAAOCAQEA j/ola09b5KROJ1WrIhVZPMq1CtRK26vdoV9TxaBXOcLORyu+OshWv8LZJxA6sQU8wHcxuzrTBXtt mhwwjIDLk5Mqg6sFUYICABFna/OIYUdfA5PVWw3g8dShMjWFsjrbsIKr0csKvE+MW8VLADsfKoKm fjaF3H48ZwC15DtS4KjrXRX5xm3wrR0OhbepmnMUWluPQSjA1egtTaRezarZ7c7c2NU8Qh0XwRJd RTjDOPP8hS6DRkiy1yBfkjaP53kPmF6Z6PDQpLv1U70qzlmwr25/bLvSHgCwIe34QWKCudiyxLtG UPMxxY8BqHTr9Xgn2uf3ZkPznoM+IKrDNWCRzg== -----END CERTIFICATE----- Entrust.net Secure Server CA ============================ -----BEGIN CERTIFICATE----- MIIE2DCCBEGgAwIBAgIEN0rSQzANBgkqhkiG9w0BAQUFADCBwzELMAkGA1UEBhMCVVMxFDASBgNV BAoTC0VudHJ1c3QubmV0MTswOQYDVQQLEzJ3d3cuZW50cnVzdC5uZXQvQ1BTIGluY29ycC4gYnkg cmVmLiAobGltaXRzIGxpYWIuKTElMCMGA1UECxMcKGMpIDE5OTkgRW50cnVzdC5uZXQgTGltaXRl ZDE6MDgGA1UEAxMxRW50cnVzdC5uZXQgU2VjdXJlIFNlcnZlciBDZXJ0aWZpY2F0aW9uIEF1dGhv cml0eTAeFw05OTA1MjUxNjA5NDBaFw0xOTA1MjUxNjM5NDBaMIHDMQswCQYDVQQGEwJVUzEUMBIG A1UEChMLRW50cnVzdC5uZXQxOzA5BgNVBAsTMnd3dy5lbnRydXN0Lm5ldC9DUFMgaW5jb3JwLiBi eSByZWYuIChsaW1pdHMgbGlhYi4pMSUwIwYDVQQLExwoYykgMTk5OSBFbnRydXN0Lm5ldCBMaW1p dGVkMTowOAYDVQQDEzFFbnRydXN0Lm5ldCBTZWN1cmUgU2VydmVyIENlcnRpZmljYXRpb24gQXV0 aG9yaXR5MIGdMA0GCSqGSIb3DQEBAQUAA4GLADCBhwKBgQDNKIM0VBuJ8w+vN5Ex/68xYMmo6LIQ aO2f55M28Qpku0f1BBc/I0dNxScZgSYMVHINiC3ZH5oSn7yzcdOAGT9HZnuMNSjSuQrfJNqc1lB5 gXpa0zf3wkrYKZImZNHkmGw6AIr1NJtl+O3jEP/9uElY3KDegjlrgbEWGWG5VLbmQwIBA6OCAdcw ggHTMBEGCWCGSAGG+EIBAQQEAwIABzCCARkGA1UdHwSCARAwggEMMIHeoIHboIHYpIHVMIHSMQsw CQYDVQQGEwJVUzEUMBIGA1UEChMLRW50cnVzdC5uZXQxOzA5BgNVBAsTMnd3dy5lbnRydXN0Lm5l dC9DUFMgaW5jb3JwLiBieSByZWYuIChsaW1pdHMgbGlhYi4pMSUwIwYDVQQLExwoYykgMTk5OSBF bnRydXN0Lm5ldCBMaW1pdGVkMTowOAYDVQQDEzFFbnRydXN0Lm5ldCBTZWN1cmUgU2VydmVyIENl cnRpZmljYXRpb24gQXV0aG9yaXR5MQ0wCwYDVQQDEwRDUkwxMCmgJ6AlhiNodHRwOi8vd3d3LmVu dHJ1c3QubmV0L0NSTC9uZXQxLmNybDArBgNVHRAEJDAigA8xOTk5MDUyNTE2MDk0MFqBDzIwMTkw NTI1MTYwOTQwWjALBgNVHQ8EBAMCAQYwHwYDVR0jBBgwFoAU8BdiE1U9s/8KAGv7UISX8+1i0Bow HQYDVR0OBBYEFPAXYhNVPbP/CgBr+1CEl/PtYtAaMAwGA1UdEwQFMAMBAf8wGQYJKoZIhvZ9B0EA BAwwChsEVjQuMAMCBJAwDQYJKoZIhvcNAQEFBQADgYEAkNwwAvpkdMKnCqV8IY00F6j7Rw7/JXyN Ewr75Ji174z4xRAN95K+8cPV1ZVqBLssziY2ZcgxxufuP+NXdYR6Ee9GTxj005i7qIcyunL2POI9 n9cd2cNgQ4xYDiKWL2KjLB+6rQXvqzJ4h6BUcxm1XAX5Uj5tLUUL9wqT6u0G+bI= -----END CERTIFICATE----- Entrust.net Premium 2048 Secure Server CA ========================================= -----BEGIN CERTIFICATE----- MIIEXDCCA0SgAwIBAgIEOGO5ZjANBgkqhkiG9w0BAQUFADCBtDEUMBIGA1UEChMLRW50cnVzdC5u ZXQxQDA+BgNVBAsUN3d3dy5lbnRydXN0Lm5ldC9DUFNfMjA0OCBpbmNvcnAuIGJ5IHJlZi4gKGxp bWl0cyBsaWFiLikxJTAjBgNVBAsTHChjKSAxOTk5IEVudHJ1c3QubmV0IExpbWl0ZWQxMzAxBgNV BAMTKkVudHJ1c3QubmV0IENlcnRpZmljYXRpb24gQXV0aG9yaXR5ICgyMDQ4KTAeFw05OTEyMjQx NzUwNTFaFw0xOTEyMjQxODIwNTFaMIG0MRQwEgYDVQQKEwtFbnRydXN0Lm5ldDFAMD4GA1UECxQ3 d3d3LmVudHJ1c3QubmV0L0NQU18yMDQ4IGluY29ycC4gYnkgcmVmLiAobGltaXRzIGxpYWIuKTEl MCMGA1UECxMcKGMpIDE5OTkgRW50cnVzdC5uZXQgTGltaXRlZDEzMDEGA1UEAxMqRW50cnVzdC5u ZXQgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgKDIwNDgpMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A MIIBCgKCAQEArU1LqRKGsuqjIAcVFmQqK0vRvwtKTY7tgHalZ7d4QMBzQshowNtTK91euHaYNZOL Gp18EzoOH1u3Hs/lJBQesYGpjX24zGtLA/ECDNyrpUAkAH90lKGdCCmziAv1h3edVc3kw37XamSr hRSGlVuXMlBvPci6Zgzj/L24ScF2iUkZ/cCovYmjZy/Gn7xxGWC4LeksyZB2ZnuU4q941mVTXTzW nLLPKQP5L6RQstRIzgUyVYr9smRMDuSYB3Xbf9+5CFVghTAp+XtIpGmG4zU/HoZdenoVve8AjhUi VBcAkCaTvA5JaJG/+EfTnZVCwQ5N328mz8MYIWJmQ3DW1cAH4QIDAQABo3QwcjARBglghkgBhvhC AQEEBAMCAAcwHwYDVR0jBBgwFoAUVeSB0RGAvtiJuQijMfmhJAkWuXAwHQYDVR0OBBYEFFXkgdER gL7YibkIozH5oSQJFrlwMB0GCSqGSIb2fQdBAAQQMA4bCFY1LjA6NC4wAwIEkDANBgkqhkiG9w0B AQUFAAOCAQEAWUesIYSKF8mciVMeuoCFGsY8Tj6xnLZ8xpJdGGQC49MGCBFhfGPjK50xA3B20qMo oPS7mmNz7W3lKtvtFKkrxjYR0CvrB4ul2p5cGZ1WEvVUKcgF7bISKo30Axv/55IQh7A6tcOdBTcS o8f0FbnVpDkWm1M6I5HxqIKiaohowXkCIryqptau37AUX7iH0N18f3v/rxzP5tsHrV7bhZ3QKw0z 2wTR5klAEyt2+z7pnIkPFc4YsIV4IU9rTw76NmfNB/L/CNDi3tm/Kq+4h4YhPATKt5Rof8886ZjX OP/swNlQ8C5LWK5Gb9Auw2DaclVyvUxFnmG6v4SBkgPR0ml8xQ== -----END CERTIFICATE----- Baltimore CyberTrust Root ========================= -----BEGIN CERTIFICATE----- MIIDdzCCAl+gAwIBAgIEAgAAuTANBgkqhkiG9w0BAQUFADBaMQswCQYDVQQGEwJJRTESMBAGA1UE ChMJQmFsdGltb3JlMRMwEQYDVQQLEwpDeWJlclRydXN0MSIwIAYDVQQDExlCYWx0aW1vcmUgQ3li ZXJUcnVzdCBSb290MB4XDTAwMDUxMjE4NDYwMFoXDTI1MDUxMjIzNTkwMFowWjELMAkGA1UEBhMC SUUxEjAQBgNVBAoTCUJhbHRpbW9yZTETMBEGA1UECxMKQ3liZXJUcnVzdDEiMCAGA1UEAxMZQmFs dGltb3JlIEN5YmVyVHJ1c3QgUm9vdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKME uyKrmD1X6CZymrV51Cni4eiVgLGw41uOKymaZN+hXe2wCQVt2yguzmKiYv60iNoS6zjrIZ3AQSsB UnuId9Mcj8e6uYi1agnnc+gRQKfRzMpijS3ljwumUNKoUMMo6vWrJYeKmpYcqWe4PwzV9/lSEy/C G9VwcPCPwBLKBsua4dnKM3p31vjsufFoREJIE9LAwqSuXmD+tqYF/LTdB1kC1FkYmGP1pWPgkAx9 XbIGevOF6uvUA65ehD5f/xXtabz5OTZydc93Uk3zyZAsuT3lySNTPx8kmCFcB5kpvcY67Oduhjpr l3RjM71oGDHweI12v/yejl0qhqdNkNwnGjkCAwEAAaNFMEMwHQYDVR0OBBYEFOWdWTCCR1jMrPoI VDaGezq1BE3wMBIGA1UdEwEB/wQIMAYBAf8CAQMwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEB BQUAA4IBAQCFDF2O5G9RaEIFoN27TyclhAO992T9Ldcw46QQF+vaKSm2eT929hkTI7gQCvlYpNRh cL0EYWoSihfVCr3FvDB81ukMJY2GQE/szKN+OMY3EU/t3WgxjkzSswF07r51XgdIGn9w/xZchMB5 hbgF/X++ZRGjD8ACtPhSNzkE1akxehi/oCr0Epn3o0WC4zxe9Z2etciefC7IpJ5OCBRLbf1wbWsa Y71k5h+3zvDyny67G7fyUIhzksLi4xaNmjICq44Y3ekQEe5+NauQrz4wlHrQMz2nZQ/1/I6eYs9H RCwBXbsdtTLSR9I4LtD+gdwyah617jzV/OeBHRnDJELqYzmp -----END CERTIFICATE----- Equifax Secure Global eBusiness CA ================================== -----BEGIN CERTIFICATE----- MIICkDCCAfmgAwIBAgIBATANBgkqhkiG9w0BAQQFADBaMQswCQYDVQQGEwJVUzEcMBoGA1UEChMT RXF1aWZheCBTZWN1cmUgSW5jLjEtMCsGA1UEAxMkRXF1aWZheCBTZWN1cmUgR2xvYmFsIGVCdXNp bmVzcyBDQS0xMB4XDTk5MDYyMTA0MDAwMFoXDTIwMDYyMTA0MDAwMFowWjELMAkGA1UEBhMCVVMx HDAaBgNVBAoTE0VxdWlmYXggU2VjdXJlIEluYy4xLTArBgNVBAMTJEVxdWlmYXggU2VjdXJlIEds b2JhbCBlQnVzaW5lc3MgQ0EtMTCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAuucXkAJlsTRV PEnCUdXfp9E3j9HngXNBUmCbnaEXJnitx7HoJpQytd4zjTov2/KaelpzmKNc6fuKcxtc58O/gGzN qfTWK8D3+ZmqY6KxRwIP1ORROhI8bIpaVIRw28HFkM9yRcuoWcDNM50/o5brhTMhHD4ePmBudpxn hcXIw2ECAwEAAaNmMGQwEQYJYIZIAYb4QgEBBAQDAgAHMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0j BBgwFoAUvqigdHJQa0S3ySPY+6j/s1draGwwHQYDVR0OBBYEFL6ooHRyUGtEt8kj2Puo/7NXa2hs MA0GCSqGSIb3DQEBBAUAA4GBADDiAVGqx+pf2rnQZQ8w1j7aDRRJbpGTJxQx78T3LUX47Me/okEN I7SS+RkAZ70Br83gcfxaz2TE4JaY0KNA4gGK7ycH8WUBikQtBmV1UsCGECAhX2xrD2yuCRyv8qIY NMR1pHMc8Y3c7635s3a0kr/clRAevsvIO1qEYBlWlKlV -----END CERTIFICATE----- Equifax Secure eBusiness CA 1 ============================= -----BEGIN CERTIFICATE----- MIICgjCCAeugAwIBAgIBBDANBgkqhkiG9w0BAQQFADBTMQswCQYDVQQGEwJVUzEcMBoGA1UEChMT RXF1aWZheCBTZWN1cmUgSW5jLjEmMCQGA1UEAxMdRXF1aWZheCBTZWN1cmUgZUJ1c2luZXNzIENB LTEwHhcNOTkwNjIxMDQwMDAwWhcNMjAwNjIxMDQwMDAwWjBTMQswCQYDVQQGEwJVUzEcMBoGA1UE ChMTRXF1aWZheCBTZWN1cmUgSW5jLjEmMCQGA1UEAxMdRXF1aWZheCBTZWN1cmUgZUJ1c2luZXNz IENBLTEwgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAM4vGbwXt3fek6lfWg0XTzQaDJj0ItlZ 1MRoRvC0NcWFAyDGr0WlIVFFQesWWDYyb+JQYmT5/VGcqiTZ9J2DKocKIdMSODRsjQBuWqDZQu4a IZX5UkxVWsUPOE9G+m34LjXWHXzr4vCwdYDIqROsvojvOm6rXyo4YgKwEnv+j6YDAgMBAAGjZjBk MBEGCWCGSAGG+EIBAQQEAwIABzAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFEp4MlIR21kW Nl7fwRQ2QGpHfEyhMB0GA1UdDgQWBBRKeDJSEdtZFjZe38EUNkBqR3xMoTANBgkqhkiG9w0BAQQF AAOBgQB1W6ibAxHm6VZMzfmpTMANmvPMZWnmJXbMWbfWVMMdzZmsGd20hdXgPfxiIKeES1hl8eL5 lSE/9dR+WB5Hh1Q+WKG1tfgq73HnvMP2sUlG4tega+VWeponmHxGYhTnyfxuAxJ5gDgdSIKN/Bf+ KpYrtWKmpj29f5JZzVoqgrI3eQ== -----END CERTIFICATE----- Equifax Secure eBusiness CA 2 ============================= -----BEGIN CERTIFICATE----- MIIDIDCCAomgAwIBAgIEN3DPtTANBgkqhkiG9w0BAQUFADBOMQswCQYDVQQGEwJVUzEXMBUGA1UE ChMORXF1aWZheCBTZWN1cmUxJjAkBgNVBAsTHUVxdWlmYXggU2VjdXJlIGVCdXNpbmVzcyBDQS0y MB4XDTk5MDYyMzEyMTQ0NVoXDTE5MDYyMzEyMTQ0NVowTjELMAkGA1UEBhMCVVMxFzAVBgNVBAoT DkVxdWlmYXggU2VjdXJlMSYwJAYDVQQLEx1FcXVpZmF4IFNlY3VyZSBlQnVzaW5lc3MgQ0EtMjCB nzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEA5Dk5kx5SBhsoNviyoynF7Y6yEb3+6+e0dMKP/wXn 2Z0GvxLIPw7y1tEkshHe0XMJitSxLJgJDR5QRrKDpkWNYmi7hRsgcDKqQM2mll/EcTc/BPO3QSQ5 BxoeLmFYoBIL5aXfxavqN3HMHMg3OrmXUqesxWoklE6ce8/AatbfIb0CAwEAAaOCAQkwggEFMHAG A1UdHwRpMGcwZaBjoGGkXzBdMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORXF1aWZheCBTZWN1cmUx JjAkBgNVBAsTHUVxdWlmYXggU2VjdXJlIGVCdXNpbmVzcyBDQS0yMQ0wCwYDVQQDEwRDUkwxMBoG A1UdEAQTMBGBDzIwMTkwNjIzMTIxNDQ1WjALBgNVHQ8EBAMCAQYwHwYDVR0jBBgwFoAUUJ4L6q9e uSBIplBqy/3YIHqngnYwHQYDVR0OBBYEFFCeC+qvXrkgSKZQasv92CB6p4J2MAwGA1UdEwQFMAMB Af8wGgYJKoZIhvZ9B0EABA0wCxsFVjMuMGMDAgbAMA0GCSqGSIb3DQEBBQUAA4GBAAyGgq3oThr1 jokn4jVYPSm0B482UJW/bsGe68SQsoWou7dC4A8HOd/7npCy0cE+U58DRLB+S/Rv5Hwf5+Kx5Lia 78O9zt4LMjTZ3ijtM2vE1Nc9ElirfQkty3D1E4qUoSek1nDFbZS1yX2doNLGCEnZZpum0/QL3MUm V+GRMOrN -----END CERTIFICATE----- AddTrust Low-Value Services Root ================================ -----BEGIN CERTIFICATE----- MIIEGDCCAwCgAwIBAgIBATANBgkqhkiG9w0BAQUFADBlMQswCQYDVQQGEwJTRTEUMBIGA1UEChML QWRkVHJ1c3QgQUIxHTAbBgNVBAsTFEFkZFRydXN0IFRUUCBOZXR3b3JrMSEwHwYDVQQDExhBZGRU cnVzdCBDbGFzcyAxIENBIFJvb3QwHhcNMDAwNTMwMTAzODMxWhcNMjAwNTMwMTAzODMxWjBlMQsw CQYDVQQGEwJTRTEUMBIGA1UEChMLQWRkVHJ1c3QgQUIxHTAbBgNVBAsTFEFkZFRydXN0IFRUUCBO ZXR3b3JrMSEwHwYDVQQDExhBZGRUcnVzdCBDbGFzcyAxIENBIFJvb3QwggEiMA0GCSqGSIb3DQEB AQUAA4IBDwAwggEKAoIBAQCWltQhSWDia+hBBwzexODcEyPNwTXH+9ZOEQpnXvUGW2ulCDtbKRY6 54eyNAbFvAWlA3yCyykQruGIgb3WntP+LVbBFc7jJp0VLhD7Bo8wBN6ntGO0/7Gcrjyvd7ZWxbWr oulpOj0OM3kyP3CCkplhbY0wCI9xP6ZIVxn4JdxLZlyldI+Yrsj5wAYi56xz36Uu+1LcsRVlIPo1 Zmne3yzxbrww2ywkEtvrNTVokMsAsJchPXQhI2U0K7t4WaPW4XY5mqRJjox0r26kmqPZm9I4XJui GMx1I4S+6+JNM3GOGvDC+Mcdoq0Dlyz4zyXG9rgkMbFjXZJ/Y/AlyVMuH79NAgMBAAGjgdIwgc8w HQYDVR0OBBYEFJWxtPCUtr3H2tERCSG+wa9J/RB7MAsGA1UdDwQEAwIBBjAPBgNVHRMBAf8EBTAD AQH/MIGPBgNVHSMEgYcwgYSAFJWxtPCUtr3H2tERCSG+wa9J/RB7oWmkZzBlMQswCQYDVQQGEwJT RTEUMBIGA1UEChMLQWRkVHJ1c3QgQUIxHTAbBgNVBAsTFEFkZFRydXN0IFRUUCBOZXR3b3JrMSEw HwYDVQQDExhBZGRUcnVzdCBDbGFzcyAxIENBIFJvb3SCAQEwDQYJKoZIhvcNAQEFBQADggEBACxt ZBsfzQ3duQH6lmM0MkhHma6X7f1yFqZzR1r0693p9db7RcwpiURdv0Y5PejuvE1Uhh4dbOMXJ0Ph iVYrqW9yTkkz43J8KiOavD7/KCrto/8cI7pDVwlnTUtiBi34/2ydYB7YHEt9tTEv2dB8Xfjea4MY eDdXL+gzB2ffHsdrKpV2ro9Xo/D0UrSpUwjP4E/TelOL/bscVjby/rK25Xa71SJlpz/+0WatC7xr mYbvP33zGDLKe8bjq2RGlfgmadlVg3sslgf/WSxEo8bl6ancoWOAWiFeIc9TVPC6b4nbqKqVz4vj ccweGyBECMB6tkD9xOQ14R0WHNC8K47Wcdk= -----END CERTIFICATE----- AddTrust External Root ====================== -----BEGIN CERTIFICATE----- MIIENjCCAx6gAwIBAgIBATANBgkqhkiG9w0BAQUFADBvMQswCQYDVQQGEwJTRTEUMBIGA1UEChML QWRkVHJ1c3QgQUIxJjAkBgNVBAsTHUFkZFRydXN0IEV4dGVybmFsIFRUUCBOZXR3b3JrMSIwIAYD VQQDExlBZGRUcnVzdCBFeHRlcm5hbCBDQSBSb290MB4XDTAwMDUzMDEwNDgzOFoXDTIwMDUzMDEw NDgzOFowbzELMAkGA1UEBhMCU0UxFDASBgNVBAoTC0FkZFRydXN0IEFCMSYwJAYDVQQLEx1BZGRU cnVzdCBFeHRlcm5hbCBUVFAgTmV0d29yazEiMCAGA1UEAxMZQWRkVHJ1c3QgRXh0ZXJuYWwgQ0Eg Um9vdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALf3GjPm8gAELTngTlvtH7xsD821 +iO2zt6bETOXpClMfZOfvUq8k+0DGuOPz+VtUFrWlymUWoCwSXrbLpX9uMq/NzgtHj6RQa1wVsfw Tz/oMp50ysiQVOnGXw94nZpAPA6sYapeFI+eh6FqUNzXmk6vBbOmcZSccbNQYArHE504B4YCqOmo aSYYkKtMsE8jqzpPhNjfzp/haW+710LXa0Tkx63ubUFfclpxCDezeWWkWaCUN/cALw3CknLa0Dhy 2xSoRcRdKn23tNbE7qzNE0S3ySvdQwAl+mG5aWpYIxG3pzOPVnVZ9c0p10a3CitlttNCbxWyuHv7 7+ldU9U0WicCAwEAAaOB3DCB2TAdBgNVHQ4EFgQUrb2YejS0Jvf6xCZU7wO94CTLVBowCwYDVR0P BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wgZkGA1UdIwSBkTCBjoAUrb2YejS0Jvf6xCZU7wO94CTL VBqhc6RxMG8xCzAJBgNVBAYTAlNFMRQwEgYDVQQKEwtBZGRUcnVzdCBBQjEmMCQGA1UECxMdQWRk VHJ1c3QgRXh0ZXJuYWwgVFRQIE5ldHdvcmsxIjAgBgNVBAMTGUFkZFRydXN0IEV4dGVybmFsIENB IFJvb3SCAQEwDQYJKoZIhvcNAQEFBQADggEBALCb4IUlwtYj4g+WBpKdQZic2YR5gdkeWxQHIzZl j7DYd7usQWxHYINRsPkyPef89iYTx4AWpb9a/IfPeHmJIZriTAcKhjW88t5RxNKWt9x+Tu5w/Rw5 6wwCURQtjr0W4MHfRnXnJK3s9EK0hZNwEGe6nQY1ShjTK3rMUUKhemPR5ruhxSvCNr4TDea9Y355 e6cJDUCrat2PisP29owaQgVR1EX1n6diIWgVIEM8med8vSTYqZEXc4g/VhsxOBi0cQ+azcgOno4u G+GMmIPLHzHxREzGBHNJdmAPx/i9F4BrLunMTA5amnkPIAou1Z5jJh5VkpTYghdae9C8x49OhgQ= -----END CERTIFICATE----- AddTrust Public Services Root ============================= -----BEGIN CERTIFICATE----- MIIEFTCCAv2gAwIBAgIBATANBgkqhkiG9w0BAQUFADBkMQswCQYDVQQGEwJTRTEUMBIGA1UEChML QWRkVHJ1c3QgQUIxHTAbBgNVBAsTFEFkZFRydXN0IFRUUCBOZXR3b3JrMSAwHgYDVQQDExdBZGRU cnVzdCBQdWJsaWMgQ0EgUm9vdDAeFw0wMDA1MzAxMDQxNTBaFw0yMDA1MzAxMDQxNTBaMGQxCzAJ BgNVBAYTAlNFMRQwEgYDVQQKEwtBZGRUcnVzdCBBQjEdMBsGA1UECxMUQWRkVHJ1c3QgVFRQIE5l dHdvcmsxIDAeBgNVBAMTF0FkZFRydXN0IFB1YmxpYyBDQSBSb290MIIBIjANBgkqhkiG9w0BAQEF AAOCAQ8AMIIBCgKCAQEA6Rowj4OIFMEg2Dybjxt+A3S72mnTRqX4jsIMEZBRpS9mVEBV6tsfSlbu nyNu9DnLoblv8n75XYcmYZ4c+OLspoH4IcUkzBEMP9smcnrHAZcHF/nXGCwwfQ56HmIexkvA/X1i d9NEHif2P0tEs7c42TkfYNVRknMDtABp4/MUTu7R3AnPdzRGULD4EfL+OHn3Bzn+UZKXC1sIXzSG Aa2Il+tmzV7R/9x98oTaunet3IAIx6eH1lWfl2royBFkuucZKT8Rs3iQhCBSWxHveNCD9tVIkNAw HM+A+WD+eeSI8t0A65RF62WUaUC6wNW0uLp9BBGo6zEFlpROWCGOn9Bg/QIDAQABo4HRMIHOMB0G A1UdDgQWBBSBPjfYkrAfd59ctKtzquf2NGAv+jALBgNVHQ8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB /zCBjgYDVR0jBIGGMIGDgBSBPjfYkrAfd59ctKtzquf2NGAv+qFopGYwZDELMAkGA1UEBhMCU0Ux FDASBgNVBAoTC0FkZFRydXN0IEFCMR0wGwYDVQQLExRBZGRUcnVzdCBUVFAgTmV0d29yazEgMB4G A1UEAxMXQWRkVHJ1c3QgUHVibGljIENBIFJvb3SCAQEwDQYJKoZIhvcNAQEFBQADggEBAAP3FUr4 JNojVhaTdt02KLmuG7jD8WS6IBh4lSknVwW8fCr0uVFV2ocC3g8WFzH4qnkuCRO7r7IgGRLlk/lL +YPoRNWyQSW/iHVv/xD8SlTQX/D67zZzfRs2RcYhbbQVuE7PnFylPVoAjgbjPGsye/Kf8Lb93/Ao GEjwxrzQvzSAlsJKsW2Ox5BF3i9nrEUEo3rcVZLJR2bYGozH7ZxOmuASu7VqTITh4SINhwBk/ox9 Yjllpu9CtoAlEmEBqCQTcAARJl/6NVDFSMwGR+gn2HCNX2TmoUQmXiLsks3/QppEIW1cxeMiHV9H EufOX1362KqxMy3ZdvJOOjMMK7MtkAY= -----END CERTIFICATE----- AddTrust Qualified Certificates Root ==================================== -----BEGIN CERTIFICATE----- MIIEHjCCAwagAwIBAgIBATANBgkqhkiG9w0BAQUFADBnMQswCQYDVQQGEwJTRTEUMBIGA1UEChML QWRkVHJ1c3QgQUIxHTAbBgNVBAsTFEFkZFRydXN0IFRUUCBOZXR3b3JrMSMwIQYDVQQDExpBZGRU cnVzdCBRdWFsaWZpZWQgQ0EgUm9vdDAeFw0wMDA1MzAxMDQ0NTBaFw0yMDA1MzAxMDQ0NTBaMGcx CzAJBgNVBAYTAlNFMRQwEgYDVQQKEwtBZGRUcnVzdCBBQjEdMBsGA1UECxMUQWRkVHJ1c3QgVFRQ IE5ldHdvcmsxIzAhBgNVBAMTGkFkZFRydXN0IFF1YWxpZmllZCBDQSBSb290MIIBIjANBgkqhkiG 9w0BAQEFAAOCAQ8AMIIBCgKCAQEA5B6a/twJWoekn0e+EV+vhDTbYjx5eLfpMLXsDBwqxBb/4Oxx 64r1EW7tTw2R0hIYLUkVAcKkIhPHEWT/IhKauY5cLwjPcWqzZwFZ8V1G87B4pfYOQnrjfxvM0PC3 KP0q6p6zsLkEqv32x7SxuCqg+1jxGaBvcCV+PmlKfw8i2O+tCBGaKZnhqkRFmhJePp1tUvznoD1o L/BLcHwTOK28FSXx1s6rosAx1i+f4P8UWfyEk9mHfExUE+uf0S0R+Bg6Ot4l2ffTQO2kBhLEO+GR wVY18BTcZTYJbqukB8c10cIDMzZbdSZtQvESa0NvS3GU+jQd7RNuyoB/mC9suWXY6QIDAQABo4HU MIHRMB0GA1UdDgQWBBQ5lYtii1zJ1IC6WA+XPxUIQ8yYpzALBgNVHQ8EBAMCAQYwDwYDVR0TAQH/ BAUwAwEB/zCBkQYDVR0jBIGJMIGGgBQ5lYtii1zJ1IC6WA+XPxUIQ8yYp6FrpGkwZzELMAkGA1UE BhMCU0UxFDASBgNVBAoTC0FkZFRydXN0IEFCMR0wGwYDVQQLExRBZGRUcnVzdCBUVFAgTmV0d29y azEjMCEGA1UEAxMaQWRkVHJ1c3QgUXVhbGlmaWVkIENBIFJvb3SCAQEwDQYJKoZIhvcNAQEFBQAD ggEBABmrder4i2VhlRO6aQTvhsoToMeqT2QbPxj2qC0sVY8FtzDqQmodwCVRLae/DLPt7wh/bDxG GuoYQ992zPlmhpwsaPXpF/gxsxjE1kh9I0xowX67ARRvxdlu3rsEQmr49lx95dr6h+sNNVJn0J6X dgWTP5XHAeZpVTh/EGGZyeNfpso+gmNIquIISD6q8rKFYqa0p9m9N5xotS1WfbC3P6CxB9bpT9ze RXEwMn8bLgn5v1Kh7sKAPgZcLlVAwRv1cEWw3F369nJad9Jjzc9YiQBCYz95OdBEsIJuQRno3eDB iFrRHnGTHyQwdOUeqN48Jzd/g66ed8/wMLH/S5noxqE= -----END CERTIFICATE----- Entrust Root Certification Authority ==================================== -----BEGIN CERTIFICATE----- MIIEkTCCA3mgAwIBAgIERWtQVDANBgkqhkiG9w0BAQUFADCBsDELMAkGA1UEBhMCVVMxFjAUBgNV BAoTDUVudHJ1c3QsIEluYy4xOTA3BgNVBAsTMHd3dy5lbnRydXN0Lm5ldC9DUFMgaXMgaW5jb3Jw b3JhdGVkIGJ5IHJlZmVyZW5jZTEfMB0GA1UECxMWKGMpIDIwMDYgRW50cnVzdCwgSW5jLjEtMCsG A1UEAxMkRW50cnVzdCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTA2MTEyNzIwMjM0 MloXDTI2MTEyNzIwNTM0MlowgbAxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1FbnRydXN0LCBJbmMu MTkwNwYDVQQLEzB3d3cuZW50cnVzdC5uZXQvQ1BTIGlzIGluY29ycG9yYXRlZCBieSByZWZlcmVu Y2UxHzAdBgNVBAsTFihjKSAyMDA2IEVudHJ1c3QsIEluYy4xLTArBgNVBAMTJEVudHJ1c3QgUm9v dCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB ALaVtkNC+sZtKm9I35RMOVcF7sN5EUFoNu3s/poBj6E4KPz3EEZmLk0eGrEaTsbRwJWIsMn/MYsz A9u3g3s+IIRe7bJWKKf44LlAcTfFy0cOlypowCKVYhXbR9n10Cv/gkvJrT7eTNuQgFA/CYqEAOww Cj0Yzfv9KlmaI5UXLEWeH25DeW0MXJj+SKfFI0dcXv1u5x609mhF0YaDW6KKjbHjKYD+JXGIrb68 j6xSlkuqUY3kEzEZ6E5Nn9uss2rVvDlUccp6en+Q3X0dgNmBu1kmwhH+5pPi94DkZfs0Nw4pgHBN rziGLp5/V6+eF67rHMsoIV+2HNjnogQi+dPa2MsCAwEAAaOBsDCBrTAOBgNVHQ8BAf8EBAMCAQYw DwYDVR0TAQH/BAUwAwEB/zArBgNVHRAEJDAigA8yMDA2MTEyNzIwMjM0MlqBDzIwMjYxMTI3MjA1 MzQyWjAfBgNVHSMEGDAWgBRokORnpKZTgMeGZqTx90tD+4S9bTAdBgNVHQ4EFgQUaJDkZ6SmU4DH hmak8fdLQ/uEvW0wHQYJKoZIhvZ9B0EABBAwDhsIVjcuMTo0LjADAgSQMA0GCSqGSIb3DQEBBQUA A4IBAQCT1DCw1wMgKtD5Y+iRDAUgqV8ZyntyTtSx29CW+1RaGSwMCPeyvIWonX9tO1KzKtvn1ISM Y/YPyyYBkVBs9F8U4pN0wBOeMDpQ47RgxRzwIkSNcUesyBrJ6ZuaAGAT/3B+XxFNSRuzFVJ7yVTa v52Vr2ua2J7p8eRDjeIRRDq/r72DQnNSi6q7pynP9WQcCk3RvKqsnyrQ/39/2n3qse0wJcGE2jTS W3iDVuycNsMm4hH2Z0kdkquM++v/eu6FSqdQgPCnXEqULl8FmTxSQeDNtGPPAUO6nIPcj2A781q0 tHuu2guQOHXvgR1m0vdXcDazv/wor3ElhVsT/h5/WrQ8 -----END CERTIFICATE----- RSA Security 2048 v3 ==================== -----BEGIN CERTIFICATE----- MIIDYTCCAkmgAwIBAgIQCgEBAQAAAnwAAAAKAAAAAjANBgkqhkiG9w0BAQUFADA6MRkwFwYDVQQK ExBSU0EgU2VjdXJpdHkgSW5jMR0wGwYDVQQLExRSU0EgU2VjdXJpdHkgMjA0OCBWMzAeFw0wMTAy MjIyMDM5MjNaFw0yNjAyMjIyMDM5MjNaMDoxGTAXBgNVBAoTEFJTQSBTZWN1cml0eSBJbmMxHTAb BgNVBAsTFFJTQSBTZWN1cml0eSAyMDQ4IFYzMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC AQEAt49VcdKA3XtpeafwGFAyPGJn9gqVB93mG/Oe2dJBVGutn3y+Gc37RqtBaB4Y6lXIL5F4iSj7 Jylg/9+PjDvJSZu1pJTOAeo+tWN7fyb9Gd3AIb2E0S1PRsNO3Ng3OTsor8udGuorryGlwSMiuLgb WhOHV4PR8CDn6E8jQrAApX2J6elhc5SYcSa8LWrg903w8bYqODGBDSnhAMFRD0xS+ARaqn1y07iH KrtjEAMqs6FPDVpeRrc9DvV07Jmf+T0kgYim3WBU6JU2PcYJk5qjEoAAVZkZR73QpXzDuvsf9/UP +Ky5tfQ3mBMY3oVbtwyCO4dvlTlYMNpuAWgXIszACwIDAQABo2MwYTAPBgNVHRMBAf8EBTADAQH/ MA4GA1UdDwEB/wQEAwIBBjAfBgNVHSMEGDAWgBQHw1EwpKrpRa41JPr/JCwz0LGdjDAdBgNVHQ4E FgQUB8NRMKSq6UWuNST6/yQsM9CxnYwwDQYJKoZIhvcNAQEFBQADggEBAF8+hnZuuDU8TjYcHnmY v/3VEhF5Ug7uMYm83X/50cYVIeiKAVQNOvtUudZj1LGqlk2iQk3UUx+LEN5/Zb5gEydxiKRz44Rj 0aRV4VCT5hsOedBnvEbIvz8XDZXmxpBp3ue0L96VfdASPz0+f00/FGj1EVDVwfSQpQgdMWD/YIwj VAqv/qFuxdF6Kmh4zx6CCiC0H63lhbJqaHVOrSU3lIW+vaHU6rcMSzyd6BIA8F+sDeGscGNz9395 nzIlQnQFgCi/vcEkllgVsRch6YlL2weIZ/QVrXA+L02FO8K32/6YaCOJ4XQP3vTFhGMpG8zLB8kA pKnXwiJPZ9d37CAFYd4= -----END CERTIFICATE----- GeoTrust Global CA ================== -----BEGIN CERTIFICATE----- MIIDVDCCAjygAwIBAgIDAjRWMA0GCSqGSIb3DQEBBQUAMEIxCzAJBgNVBAYTAlVTMRYwFAYDVQQK Ew1HZW9UcnVzdCBJbmMuMRswGQYDVQQDExJHZW9UcnVzdCBHbG9iYWwgQ0EwHhcNMDIwNTIxMDQw MDAwWhcNMjIwNTIxMDQwMDAwWjBCMQswCQYDVQQGEwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5j LjEbMBkGA1UEAxMSR2VvVHJ1c3QgR2xvYmFsIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB CgKCAQEA2swYYzD99BcjGlZ+W988bDjkcbd4kdS8odhM+KhDtgPpTSEHCIjaWC9mOSm9BXiLnTjo BbdqfnGk5sRgprDvgOSJKA+eJdbtg/OtppHHmMlCGDUUna2YRpIuT8rxh0PBFpVXLVDviS2Aelet 8u5fa9IAjbkU+BQVNdnARqN7csiRv8lVK83Qlz6cJmTM386DGXHKTubU1XupGc1V3sjs0l44U+Vc T4wt/lAjNvxm5suOpDkZALeVAjmRCw7+OC7RHQWa9k0+bw8HHa8sHo9gOeL6NlMTOdReJivbPagU vTLrGAMoUgRx5aszPeE4uwc2hGKceeoWMPRfwCvocWvk+QIDAQABo1MwUTAPBgNVHRMBAf8EBTAD AQH/MB0GA1UdDgQWBBTAephojYn7qwVkDBF9qn1luMrMTjAfBgNVHSMEGDAWgBTAephojYn7qwVk DBF9qn1luMrMTjANBgkqhkiG9w0BAQUFAAOCAQEANeMpauUvXVSOKVCUn5kaFOSPeCpilKInZ57Q zxpeR+nBsqTP3UEaBU6bS+5Kb1VSsyShNwrrZHYqLizz/Tt1kL/6cdjHPTfStQWVYrmm3ok9Nns4 d0iXrKYgjy6myQzCsplFAMfOEVEiIuCl6rYVSAlk6l5PdPcFPseKUgzbFbS9bZvlxrFUaKnjaZC2 mqUPuLk/IH2uSrW4nOQdtqvmlKXBx4Ot2/Unhw4EbNX/3aBd7YdStysVAq45pmp06drE57xNNB6p XE0zX5IJL4hmXXeXxx12E6nV5fEWCRE11azbJHFwLJhWC9kXtNHjUStedejV0NxPNO3CBWaAocvm Mw== -----END CERTIFICATE----- GeoTrust Global CA 2 ==================== -----BEGIN CERTIFICATE----- MIIDZjCCAk6gAwIBAgIBATANBgkqhkiG9w0BAQUFADBEMQswCQYDVQQGEwJVUzEWMBQGA1UEChMN R2VvVHJ1c3QgSW5jLjEdMBsGA1UEAxMUR2VvVHJ1c3QgR2xvYmFsIENBIDIwHhcNMDQwMzA0MDUw MDAwWhcNMTkwMzA0MDUwMDAwWjBEMQswCQYDVQQGEwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5j LjEdMBsGA1UEAxMUR2VvVHJ1c3QgR2xvYmFsIENBIDIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAw ggEKAoIBAQDvPE1APRDfO1MA4Wf+lGAVPoWI8YkNkMgoI5kF6CsgncbzYEbYwbLVjDHZ3CB5JIG/ NTL8Y2nbsSpr7iFY8gjpeMtvy/wWUsiRxP89c96xPqfCfWbB9X5SJBri1WeR0IIQ13hLTytCOb1k LUCgsBDTOEhGiKEMuzozKmKY+wCdE1l/bztyqu6mD4b5BWHqZ38MN5aL5mkWRxHCJ1kDs6ZgwiFA Vvqgx306E+PsV8ez1q6diYD3Aecs9pYrEw15LNnA5IZ7S4wMcoKK+xfNAGw6EzywhIdLFnopsk/b HdQL82Y3vdj2V7teJHq4PIu5+pIaGoSe2HSPqht/XvT+RSIhAgMBAAGjYzBhMA8GA1UdEwEB/wQF MAMBAf8wHQYDVR0OBBYEFHE4NvICMVNHK266ZUapEBVYIAUJMB8GA1UdIwQYMBaAFHE4NvICMVNH K266ZUapEBVYIAUJMA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQUFAAOCAQEAA/e1K6tdEPx7 srJerJsOflN4WT5CBP51o62sgU7XAotexC3IUnbHLB/8gTKY0UvGkpMzNTEv/NgdRN3ggX+d6Yvh ZJFiCzkIjKx0nVnZellSlxG5FntvRdOW2TF9AjYPnDtuzywNA0ZF66D0f0hExghAzN4bcLUprbqL OzRldRtxIR0sFAqwlpW41uryZfspuk/qkZN0abby/+Ea0AzRdoXLiiW9l14sbxWZJue2Kf8i7MkC x1YAzUm5s2x7UwQa4qjJqhIFI8LO57sEAszAR6LkxCkvW0VXiVHuPOtSCP8HNR6fNWpHSlaY0VqF H4z1Ir+rzoPz4iIprn2DQKi6bA== -----END CERTIFICATE----- GeoTrust Universal CA ===================== -----BEGIN CERTIFICATE----- MIIFaDCCA1CgAwIBAgIBATANBgkqhkiG9w0BAQUFADBFMQswCQYDVQQGEwJVUzEWMBQGA1UEChMN R2VvVHJ1c3QgSW5jLjEeMBwGA1UEAxMVR2VvVHJ1c3QgVW5pdmVyc2FsIENBMB4XDTA0MDMwNDA1 MDAwMFoXDTI5MDMwNDA1MDAwMFowRTELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IElu Yy4xHjAcBgNVBAMTFUdlb1RydXN0IFVuaXZlcnNhbCBDQTCCAiIwDQYJKoZIhvcNAQEBBQADggIP ADCCAgoCggIBAKYVVaCjxuAfjJ0hUNfBvitbtaSeodlyWL0AG0y/YckUHUWCq8YdgNY96xCcOq9t JPi8cQGeBvV8Xx7BDlXKg5pZMK4ZyzBIle0iN430SppyZj6tlcDgFgDgEB8rMQ7XlFTTQjOgNB0e RXbdT8oYN+yFFXoZCPzVx5zw8qkuEKmS5j1YPakWaDwvdSEYfyh3peFhF7em6fgemdtzbvQKoiFs 7tqqhZJmr/Z6a4LauiIINQ/PQvE1+mrufislzDoR5G2vc7J2Ha3QsnhnGqQ5HFELZ1aD/ThdDc7d 8Lsrlh/eezJS/R27tQahsiFepdaVaH/wmZ7cRQg+59IJDTWU3YBOU5fXtQlEIGQWFwMCTFMNaN7V qnJNk22CDtucvc+081xdVHppCZbW2xHBjXWotM85yM48vCR85mLK4b19p71XZQvk/iXttmkQ3Cga Rr0BHdCXteGYO8A3ZNY9lO4L4fUorgtWv3GLIylBjobFS1J72HGrH4oVpjuDWtdYAVHGTEHZf9hB Z3KiKN9gg6meyHv8U3NyWfWTehd2Ds735VzZC1U0oqpbtWpU5xPKV+yXbfReBi9Fi1jUIxaS5BZu KGNZMN9QAZxjiRqf2xeUgnA3wySemkfWWspOqGmJch+RbNt+nhutxx9z3SxPGWX9f5NAEC7S8O08 ni4oPmkmM8V7AgMBAAGjYzBhMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFNq7LqqwDLiIJlF0 XG0D08DYj3rWMB8GA1UdIwQYMBaAFNq7LqqwDLiIJlF0XG0D08DYj3rWMA4GA1UdDwEB/wQEAwIB hjANBgkqhkiG9w0BAQUFAAOCAgEAMXjmx7XfuJRAyXHEqDXsRh3ChfMoWIawC/yOsjmPRFWrZIRc aanQmjg8+uUfNeVE44B5lGiku8SfPeE0zTBGi1QrlaXv9z+ZhP015s8xxtxqv6fXIwjhmF7DWgh2 qaavdy+3YL1ERmrvl/9zlcGO6JP7/TG37FcREUWbMPEaiDnBTzynANXH/KttgCJwpQzgXQQpAvvL oJHRfNbDflDVnVi+QTjruXU8FdmbyUqDWcDaU/0zuzYYm4UPFd3uLax2k7nZAY1IEKj79TiG8dsK xr2EoyNB3tZ3b4XUhRxQ4K5RirqNPnbiucon8l+f725ZDQbYKxek0nxru18UGkiPGkzns0ccjkxF KyDuSN/n3QmOGKjaQI2SJhFTYXNd673nxE0pN2HrrDktZy4W1vUAg4WhzH92xH3kt0tm7wNFYGm2 DFKWkoRepqO1pD4r2czYG0eq8kTaT/kD6PAUyz/zg97QwVTjt+gKN02LIFkDMBmhLMi9ER/frslK xfMnZmaGrGiR/9nmUxwPi1xpZQomyB40w11Re9epnAahNt3ViZS82eQtDF4JbAiXfKM9fJP/P6EU p8+1Xevb2xzEdt+Iub1FBZUbrvxGakyvSOPOrg/SfuvmbJxPgWp6ZKy7PtXny3YuxadIwVyQD8vI P/rmMuGNG2+k5o7Y+SlIis5z/iw= -----END CERTIFICATE----- GeoTrust Universal CA 2 ======================= -----BEGIN CERTIFICATE----- MIIFbDCCA1SgAwIBAgIBATANBgkqhkiG9w0BAQUFADBHMQswCQYDVQQGEwJVUzEWMBQGA1UEChMN R2VvVHJ1c3QgSW5jLjEgMB4GA1UEAxMXR2VvVHJ1c3QgVW5pdmVyc2FsIENBIDIwHhcNMDQwMzA0 MDUwMDAwWhcNMjkwMzA0MDUwMDAwWjBHMQswCQYDVQQGEwJVUzEWMBQGA1UEChMNR2VvVHJ1c3Qg SW5jLjEgMB4GA1UEAxMXR2VvVHJ1c3QgVW5pdmVyc2FsIENBIDIwggIiMA0GCSqGSIb3DQEBAQUA A4ICDwAwggIKAoICAQCzVFLByT7y2dyxUxpZKeexw0Uo5dfR7cXFS6GqdHtXr0om/Nj1XqduGdt0 DE81WzILAePb63p3NeqqWuDW6KFXlPCQo3RWlEQwAx5cTiuFJnSCegx2oG9NzkEtoBUGFF+3Qs17 j1hhNNwqCPkuwwGmIkQcTAeC5lvO0Ep8BNMZcyfwqph/Lq9O64ceJHdqXbboW0W63MOhBW9Wjo8Q JqVJwy7XQYci4E+GymC16qFjwAGXEHm9ADwSbSsVsaxLse4YuU6W3Nx2/zu+z18DwPw76L5GG//a QMJS9/7jOvdqdzXQ2o3rXhhqMcceujwbKNZrVMaqW9eiLBsZzKIC9ptZvTdrhrVtgrrY6slWvKk2 WP0+GfPtDCapkzj4T8FdIgbQl+rhrcZV4IErKIM6+vR7IVEAvlI4zs1meaj0gVbi0IMJR1FbUGrP 20gaXT73y/Zl92zxlfgCOzJWgjl6W70viRu/obTo/3+NjN8D8WBOWBFM66M/ECuDmgFz2ZRthAAn ZqzwcEAJQpKtT5MNYQlRJNiS1QuUYbKHsu3/mjX/hVTK7URDrBs8FmtISgocQIgfksILAAX/8sgC SqSqqcyZlpwvWOB94b67B9xfBHJcMTTD7F8t4D1kkCLm0ey4Lt1ZrtmhN79UNdxzMk+MBB4zsslG 8dhcyFVQyWi9qLo2CQIDAQABo2MwYTAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBR281Xh+qQ2 +/CfXGJx7Tz0RzgQKzAfBgNVHSMEGDAWgBR281Xh+qQ2+/CfXGJx7Tz0RzgQKzAOBgNVHQ8BAf8E BAMCAYYwDQYJKoZIhvcNAQEFBQADggIBAGbBxiPz2eAubl/oz66wsCVNK/g7WJtAJDday6sWSf+z dXkzoS9tcBc0kf5nfo/sm+VegqlVHy/c1FEHEv6sFj4sNcZj/NwQ6w2jqtB8zNHQL1EuxBRa3ugZ 4T7GzKQp5y6EqgYweHZUcyiYWTjgAA1i00J9IZ+uPTqM1fp3DRgrFg5fNuH8KrUwJM/gYwx7WBr+ mbpCErGR9Hxo4sjoryzqyX6uuyo9DRXcNJW2GHSoag/HtPQTxORb7QrSpJdMKu0vbBKJPfEncKpq A1Ihn0CoZ1Dy81of398j9tx4TuaYT1U6U+Pv8vSfx3zYWK8pIpe44L2RLrB27FcRz+8pRPPphXpg Y+RdM4kX2TGq2tbzGDVyz4crL2MjhF2EjD9XoIj8mZEoJmmZ1I+XRL6O1UixpCgp8RW04eWe3fiP pm8m1wk8OhwRDqZsN/etRIcsKMfYdIKz0G9KV7s1KSegi+ghp4dkNl3M2Basx7InQJJVOCiNUW7d FGdTbHFcJoRNdVq2fmBWqU2t+5sel/MN2dKXVHfaPRK34B7vCAas+YWH6aLcr34YEoP9VhdBLtUp gn2Z9DH2canPLAEnpQW5qrJITirvn5NSUZU8UnOOVkwXQMAJKOSLakhT2+zNVVXxxvjpoixMptEm X36vWkzaH6byHCx+rgIW0lbQL1dTR+iS -----END CERTIFICATE----- America Online Root Certification Authority 1 ============================================= -----BEGIN CERTIFICATE----- MIIDpDCCAoygAwIBAgIBATANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEcMBoGA1UEChMT QW1lcmljYSBPbmxpbmUgSW5jLjE2MDQGA1UEAxMtQW1lcmljYSBPbmxpbmUgUm9vdCBDZXJ0aWZp Y2F0aW9uIEF1dGhvcml0eSAxMB4XDTAyMDUyODA2MDAwMFoXDTM3MTExOTIwNDMwMFowYzELMAkG A1UEBhMCVVMxHDAaBgNVBAoTE0FtZXJpY2EgT25saW5lIEluYy4xNjA0BgNVBAMTLUFtZXJpY2Eg T25saW5lIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgMTCCASIwDQYJKoZIhvcNAQEBBQAD ggEPADCCAQoCggEBAKgv6KRpBgNHw+kqmP8ZonCaxlCyfqXfaE0bfA+2l2h9LaaLl+lkhsmj76CG v2BlnEtUiMJIxUo5vxTjWVXlGbR0yLQFOVwWpeKVBeASrlmLojNoWBym1BW32J/X3HGrfpq/m44z DyL9Hy7nBzbvYjnF3cu6JRQj3gzGPTzOggjmZj7aUTsWOqMFf6Dch9Wc/HKpoH145LcxVR5lu9Rh sCFg7RAycsWSJR74kEoYeEfffjA3PlAb2xzTa5qGUwew76wGePiEmf4hjUyAtgyC9mZweRrTT6PP 8c9GsEsPPt2IYriMqQkoO3rHl+Ee5fSfwMCuJKDIodkP1nsmgmkyPacCAwEAAaNjMGEwDwYDVR0T AQH/BAUwAwEB/zAdBgNVHQ4EFgQUAK3Zo/Z59m50qX8zPYEX10zPM94wHwYDVR0jBBgwFoAUAK3Z o/Z59m50qX8zPYEX10zPM94wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBBQUAA4IBAQB8itEf GDeC4Liwo+1WlchiYZwFos3CYiZhzRAW18y0ZTTQEYqtqKkFZu90821fnZmv9ov761KyBZiibyrF VL0lvV+uyIbqRizBs73B6UlwGBaXCBOMIOAbLjpHyx7kADCVW/RFo8AasAFOq73AI25jP4BKxQft 3OJvx8Fi8eNy1gTIdGcL+oiroQHIb/AUr9KZzVGTfu0uOMe9zkZQPXLjeSWdm4grECDdpbgyn43g Kd8hdIaC2y+CMMbHNYaz+ZZfRtsMRf3zUMNvxsNIrUam4SdHCh0Om7bCd39j8uB9Gr784N/Xx6ds sPmuujz9dLQR6FgNgLzTqIA6me11zEZ7 -----END CERTIFICATE----- America Online Root Certification Authority 2 ============================================= -----BEGIN CERTIFICATE----- MIIFpDCCA4ygAwIBAgIBATANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEcMBoGA1UEChMT QW1lcmljYSBPbmxpbmUgSW5jLjE2MDQGA1UEAxMtQW1lcmljYSBPbmxpbmUgUm9vdCBDZXJ0aWZp Y2F0aW9uIEF1dGhvcml0eSAyMB4XDTAyMDUyODA2MDAwMFoXDTM3MDkyOTE0MDgwMFowYzELMAkG A1UEBhMCVVMxHDAaBgNVBAoTE0FtZXJpY2EgT25saW5lIEluYy4xNjA0BgNVBAMTLUFtZXJpY2Eg T25saW5lIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgMjCCAiIwDQYJKoZIhvcNAQEBBQAD ggIPADCCAgoCggIBAMxBRR3pPU0Q9oyxQcngXssNt79Hc9PwVU3dxgz6sWYFas14tNwC206B89en fHG8dWOgXeMHDEjsJcQDIPT/DjsS/5uN4cbVG7RtIuOx238hZK+GvFciKtZHgVdEglZTvYYUAQv8 f3SkWq7xuhG1m1hagLQ3eAkzfDJHA1zEpYNI9FdWboE2JxhP7JsowtS013wMPgwr38oE18aO6lhO qKSlGBxsRZijQdEt0sdtjRnxrXm3gT+9BoInLRBYBbV4Bbkv2wxrkJB+FFk4u5QkE+XRnRTf04JN RvCAOVIyD+OEsnpD8l7eXz8d3eOyG6ChKiMDbi4BFYdcpnV1x5dhvt6G3NRI270qv0pV2uh9UPu0 gBe4lL8BPeraunzgWGcXuVjgiIZGZ2ydEEdYMtA1fHkqkKJaEBEjNa0vzORKW6fIJ/KD3l67Xnfn 6KVuY8INXWHQjNJsWiEOyiijzirplcdIz5ZvHZIlyMbGwcEMBawmxNJ10uEqZ8A9W6Wa6897Gqid FEXlD6CaZd4vKL3Ob5Rmg0gp2OpljK+T2WSfVVcmv2/LNzGZo2C7HK2JNDJiuEMhBnIMoVxtRsX6 Kc8w3onccVvdtjc+31D1uAclJuW8tf48ArO3+L5DwYcRlJ4jbBeKuIonDFRH8KmzwICMoCfrHRnj B453cMor9H124HhnAgMBAAGjYzBhMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFE1FwWg4u3Op aaEg5+31IqEjFNeeMB8GA1UdIwQYMBaAFE1FwWg4u3OpaaEg5+31IqEjFNeeMA4GA1UdDwEB/wQE AwIBhjANBgkqhkiG9w0BAQUFAAOCAgEAZ2sGuV9FOypLM7PmG2tZTiLMubekJcmnxPBUlgtk87FY T15R/LKXeydlwuXK5w0MJXti4/qftIe3RUavg6WXSIylvfEWK5t2LHo1YGwRgJfMqZJS5ivmae2p +DYtLHe/YUjRYwu5W1LtGLBDQiKmsXeu3mnFzcccobGlHBD7GL4acN3Bkku+KVqdPzW+5X1R+FXg JXUjhx5c3LqdsKyzadsXg8n33gy8CNyRnqjQ1xU3c6U1uPx+xURABsPr+CKAXEfOAuMRn0T//Zoy zH1kUQ7rVyZ2OuMeIjzCpjbdGe+n/BLzJsBZMYVMnNjP36TMzCmT/5RtdlwTCJfy7aULTd3oyWgO ZtMADjMSW7yV5TKQqLPGbIOtd+6Lfn6xqavT4fG2wLHqiMDn05DpKJKUe2h7lyoKZy2FAjgQ5ANh 1NolNscIWC2hp1GvMApJ9aZphwctREZ2jirlmjvXGKL8nDgQzMY70rUXOm/9riW99XJZZLF0Kjhf GEzfz3EEWjbUvy+ZnOjZurGV5gJLIaFb1cFPj65pbVPbAZO1XB4Y3WRayhgoPmMEEf0cjQAPuDff Z4qdZqkCapH/E8ovXYO8h5Ns3CRRFgQlZvqz2cK6Kb6aSDiCmfS/O0oxGfm/jiEzFMpPVF/7zvuP cX/9XhmgD0uRuMRUvAawRY8mkaKO/qk= -----END CERTIFICATE----- Visa eCommerce Root =================== -----BEGIN CERTIFICATE----- MIIDojCCAoqgAwIBAgIQE4Y1TR0/BvLB+WUF1ZAcYjANBgkqhkiG9w0BAQUFADBrMQswCQYDVQQG EwJVUzENMAsGA1UEChMEVklTQTEvMC0GA1UECxMmVmlzYSBJbnRlcm5hdGlvbmFsIFNlcnZpY2Ug QXNzb2NpYXRpb24xHDAaBgNVBAMTE1Zpc2EgZUNvbW1lcmNlIFJvb3QwHhcNMDIwNjI2MDIxODM2 WhcNMjIwNjI0MDAxNjEyWjBrMQswCQYDVQQGEwJVUzENMAsGA1UEChMEVklTQTEvMC0GA1UECxMm VmlzYSBJbnRlcm5hdGlvbmFsIFNlcnZpY2UgQXNzb2NpYXRpb24xHDAaBgNVBAMTE1Zpc2EgZUNv bW1lcmNlIFJvb3QwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvV95WHm6h2mCxlCfL F9sHP4CFT8icttD0b0/Pmdjh28JIXDqsOTPHH2qLJj0rNfVIsZHBAk4ElpF7sDPwsRROEW+1QK8b RaVK7362rPKgH1g/EkZgPI2h4H3PVz4zHvtH8aoVlwdVZqW1LS7YgFmypw23RuwhY/81q6UCzyr0 TP579ZRdhE2o8mCP2w4lPJ9zcc+U30rq299yOIzzlr3xF7zSujtFWsan9sYXiwGd/BmoKoMWuDpI /k4+oKsGGelT84ATB+0tvz8KPFUgOSwsAGl0lUq8ILKpeeUYiZGo3BxN77t+Nwtd/jmliFKMAGzs GHxBvfaLdXe6YJ2E5/4tAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEG MB0GA1UdDgQWBBQVOIMPPyw/cDMezUb+B4wg4NfDtzANBgkqhkiG9w0BAQUFAAOCAQEAX/FBfXxc CLkr4NWSR/pnXKUTwwMhmytMiUbPWU3J/qVAtmPN3XEolWcRzCSs00Rsca4BIGsDoo8Ytyk6feUW YFN4PMCvFYP3j1IzJL1kk5fui/fbGKhtcbP3LBfQdCVp9/5rPJS+TUtBjE7ic9DjkCJzQ83z7+pz zkWKsKZJ/0x9nXGIxHYdkFsd7v3M9+79YKWxehZx0RbQfBI8bGmX265fOZpwLwU8GUYEmSA20GBu YQa7FkKMcPcw++DbZqMAAb3mLNqRX6BGi01qnD093QVG/na/oAo85ADmJ7f/hC3euiInlhBx6yLt 398znM/jra6O1I7mT1GvFpLgXPYHDw== -----END CERTIFICATE----- Certum Root CA ============== -----BEGIN CERTIFICATE----- MIIDDDCCAfSgAwIBAgIDAQAgMA0GCSqGSIb3DQEBBQUAMD4xCzAJBgNVBAYTAlBMMRswGQYDVQQK ExJVbml6ZXRvIFNwLiB6IG8uby4xEjAQBgNVBAMTCUNlcnR1bSBDQTAeFw0wMjA2MTExMDQ2Mzla Fw0yNzA2MTExMDQ2MzlaMD4xCzAJBgNVBAYTAlBMMRswGQYDVQQKExJVbml6ZXRvIFNwLiB6IG8u by4xEjAQBgNVBAMTCUNlcnR1bSBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAM6x wS7TT3zNJc4YPk/EjG+AanPIW1H4m9LcuwBcsaD8dQPugfCI7iNS6eYVM42sLQnFdvkrOYCJ5JdL kKWoePhzQ3ukYbDYWMzhbGZ+nPMJXlVjhNWo7/OxLjBos8Q82KxujZlakE403Daaj4GIULdtlkIJ 89eVgw1BS7Bqa/j8D35in2fE7SZfECYPCE/wpFcozo+47UX2bu4lXapuOb7kky/ZR6By6/qmW6/K Uz/iDsaWVhFu9+lmqSbYf5VT7QqFiLpPKaVCjF62/IUgAKpoC6EahQGcxEZjgoi2IrHu/qpGWX7P NSzVttpd90gzFFS269lvzs2I1qsb2pY7HVkCAwEAAaMTMBEwDwYDVR0TAQH/BAUwAwEB/zANBgkq hkiG9w0BAQUFAAOCAQEAuI3O7+cUus/usESSbLQ5PqKEbq24IXfS1HeCh+YgQYHu4vgRt2PRFze+ GXYkHAQaTOs9qmdvLdTN/mUxcMUbpgIKumB7bVjCmkn+YzILa+M6wKyrO7Do0wlRjBCDxjTgxSvg GrZgFCdsMneMvLJymM/NzD+5yCRCFNZX/OYmQ6kd5YCQzgNUKD73P9P4Te1qCjqTE5s7FCMTY5w/ 0YcneeVMUeMBrYVdGjux1XMQpNPyvG5k9VpWkKjHDkx0Dy5xO/fIR/RpbxXyEV6DHpx8Uq79AtoS qFlnGNu8cN2bsWntgM6JQEhqDjXKKWYVIZQs6GAqm4VKQPNriiTsBhYscw== -----END CERTIFICATE----- Comodo AAA Services root ======================== -----BEGIN CERTIFICATE----- MIIEMjCCAxqgAwIBAgIBATANBgkqhkiG9w0BAQUFADB7MQswCQYDVQQGEwJHQjEbMBkGA1UECAwS R3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHDAdTYWxmb3JkMRowGAYDVQQKDBFDb21vZG8gQ0Eg TGltaXRlZDEhMB8GA1UEAwwYQUFBIENlcnRpZmljYXRlIFNlcnZpY2VzMB4XDTA0MDEwMTAwMDAw MFoXDTI4MTIzMTIzNTk1OVowezELMAkGA1UEBhMCR0IxGzAZBgNVBAgMEkdyZWF0ZXIgTWFuY2hl c3RlcjEQMA4GA1UEBwwHU2FsZm9yZDEaMBgGA1UECgwRQ29tb2RvIENBIExpbWl0ZWQxITAfBgNV BAMMGEFBQSBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC ggEBAL5AnfRu4ep2hxxNRUSOvkbIgwadwSr+GB+O5AL686tdUIoWMQuaBtDFcCLNSS1UY8y2bmhG C1Pqy0wkwLxyTurxFa70VJoSCsN6sjNg4tqJVfMiWPPe3M/vg4aijJRPn2jymJBGhCfHdr/jzDUs i14HZGWCwEiwqJH5YZ92IFCokcdmtet4YgNW8IoaE+oxox6gmf049vYnMlhvB/VruPsUK6+3qszW Y19zjNoFmag4qMsXeDZRrOme9Hg6jc8P2ULimAyrL58OAd7vn5lJ8S3frHRNG5i1R8XlKdH5kBjH Ypy+g8cmez6KJcfA3Z3mNWgQIJ2P2N7Sw4ScDV7oL8kCAwEAAaOBwDCBvTAdBgNVHQ4EFgQUoBEK Iz6W8Qfs4q8p74Klf9AwpLQwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wewYDVR0f BHQwcjA4oDagNIYyaHR0cDovL2NybC5jb21vZG9jYS5jb20vQUFBQ2VydGlmaWNhdGVTZXJ2aWNl cy5jcmwwNqA0oDKGMGh0dHA6Ly9jcmwuY29tb2RvLm5ldC9BQUFDZXJ0aWZpY2F0ZVNlcnZpY2Vz LmNybDANBgkqhkiG9w0BAQUFAAOCAQEACFb8AvCb6P+k+tZ7xkSAzk/ExfYAWMymtrwUSWgEdujm 7l3sAg9g1o1QGE8mTgHj5rCl7r+8dFRBv/38ErjHT1r0iWAFf2C3BUrz9vHCv8S5dIa2LX1rzNLz Rt0vxuBqw8M0Ayx9lt1awg6nCpnBBYurDC/zXDrPbDdVCYfeU0BsWO/8tqtlbgT2G9w84FoVxp7Z 8VlIMCFlA2zs6SFz7JsDoeA3raAVGI/6ugLOpyypEBMs1OUIJqsil2D4kF501KKaU73yqWjgom7C 12yxow+ev+to51byrvLjKzg6CYG1a4XXvi3tPxq3smPi9WIsgtRqAEFQ8TmDn5XpNpaYbg== -----END CERTIFICATE----- Comodo Secure Services root =========================== -----BEGIN CERTIFICATE----- MIIEPzCCAyegAwIBAgIBATANBgkqhkiG9w0BAQUFADB+MQswCQYDVQQGEwJHQjEbMBkGA1UECAwS R3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHDAdTYWxmb3JkMRowGAYDVQQKDBFDb21vZG8gQ0Eg TGltaXRlZDEkMCIGA1UEAwwbU2VjdXJlIENlcnRpZmljYXRlIFNlcnZpY2VzMB4XDTA0MDEwMTAw MDAwMFoXDTI4MTIzMTIzNTk1OVowfjELMAkGA1UEBhMCR0IxGzAZBgNVBAgMEkdyZWF0ZXIgTWFu Y2hlc3RlcjEQMA4GA1UEBwwHU2FsZm9yZDEaMBgGA1UECgwRQ29tb2RvIENBIExpbWl0ZWQxJDAi BgNVBAMMG1NlY3VyZSBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczCCASIwDQYJKoZIhvcNAQEBBQADggEP ADCCAQoCggEBAMBxM4KK0HDrc4eCQNUd5MvJDkKQ+d40uaG6EfQlhfPMcm3ye5drswfxdySRXyWP 9nQ95IDC+DwN879A6vfIUtFyb+/Iq0G4bi4XKpVpDM3SHpR7LZQdqnXXs5jLrLxkU0C8j6ysNstc rbvd4JQX7NFc0L/vpZXJkMWwrPsbQ996CF23uPJAGysnnlDOXmWCiIxe004MeuoIkbY2qitC++rC oznl2yY4rYsK7hljxxwk3wN42ubqwUcaCwtGCd0C/N7Lh1/XMGNooa7cMqG6vv5Eq2i2pRcV/b3V p6ea5EQz6YiO/O1R65NxTq0B50SOqy3LqP4BSUjwwN3HaNiS/j0CAwEAAaOBxzCBxDAdBgNVHQ4E FgQUPNiTiMLAggnMAZkGkyDpnnAJY08wDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8w gYEGA1UdHwR6MHgwO6A5oDeGNWh0dHA6Ly9jcmwuY29tb2RvY2EuY29tL1NlY3VyZUNlcnRpZmlj YXRlU2VydmljZXMuY3JsMDmgN6A1hjNodHRwOi8vY3JsLmNvbW9kby5uZXQvU2VjdXJlQ2VydGlm aWNhdGVTZXJ2aWNlcy5jcmwwDQYJKoZIhvcNAQEFBQADggEBAIcBbSMdflsXfcFhMs+P5/OKlFlm 4J4oqF7Tt/Q05qo5spcWxYJvMqTpjOev/e/C6LlLqqP05tqNZSH7uoDrJiiFGv45jN5bBAS0VPmj Z55B+glSzAVIqMk/IQQezkhr/IXownuvf7fM+F86/TXGDe+X3EyrEeFryzHRbPtIgKvcnDe4IRRL DXE97IMzbtFuMhbsmMcWi1mmNKsFVy2T96oTy9IT4rcuO81rUBcJaD61JlfutuC23bkpgHl9j6Pw pCikFcSF9CfUa7/lXORlAnZUtOM3ZiTTGWHIUhDlizeauan5Hb/qmZJhlv8BzaFfDbxxvA6sCx1H RR3B7Hzs/Sk= -----END CERTIFICATE----- Comodo Trusted Services root ============================ -----BEGIN CERTIFICATE----- MIIEQzCCAyugAwIBAgIBATANBgkqhkiG9w0BAQUFADB/MQswCQYDVQQGEwJHQjEbMBkGA1UECAwS R3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHDAdTYWxmb3JkMRowGAYDVQQKDBFDb21vZG8gQ0Eg TGltaXRlZDElMCMGA1UEAwwcVHJ1c3RlZCBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczAeFw0wNDAxMDEw MDAwMDBaFw0yODEyMzEyMzU5NTlaMH8xCzAJBgNVBAYTAkdCMRswGQYDVQQIDBJHcmVhdGVyIE1h bmNoZXN0ZXIxEDAOBgNVBAcMB1NhbGZvcmQxGjAYBgNVBAoMEUNvbW9kbyBDQSBMaW1pdGVkMSUw IwYDVQQDDBxUcnVzdGVkIENlcnRpZmljYXRlIFNlcnZpY2VzMIIBIjANBgkqhkiG9w0BAQEFAAOC AQ8AMIIBCgKCAQEA33FvNlhTWvI2VFeAxHQIIO0Yfyod5jWaHiWsnOWWfnJSoBVC21ndZHoa0Lh7 3TkVvFVIxO06AOoxEbrycXQaZ7jPM8yoMa+j49d/vzMtTGo87IvDktJTdyR0nAducPy9C1t2ul/y /9c3S0pgePfw+spwtOpZqqPOSC+pw7ILfhdyFgymBwwbOM/JYrc/oJOlh0Hyt3BAd9i+FHzjqMB6 juljatEPmsbS9Is6FARW1O24zG71++IsWL1/T2sr92AkWCTOJu80kTrV44HQsvAEAtdbtz6SrGsS ivnkBbA7kUlcsutT6vifR4buv5XAwAaf0lteERv0xwQ1KdJVXOTt6wIDAQABo4HJMIHGMB0GA1Ud DgQWBBTFe1i97doladL3WRaoszLAeydb9DAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB /zCBgwYDVR0fBHwwejA8oDqgOIY2aHR0cDovL2NybC5jb21vZG9jYS5jb20vVHJ1c3RlZENlcnRp ZmljYXRlU2VydmljZXMuY3JsMDqgOKA2hjRodHRwOi8vY3JsLmNvbW9kby5uZXQvVHJ1c3RlZENl cnRpZmljYXRlU2VydmljZXMuY3JsMA0GCSqGSIb3DQEBBQUAA4IBAQDIk4E7ibSvuIQSTI3S8Ntw uleGFTQQuS9/HrCoiWChisJ3DFBKmwCL2Iv0QeLQg4pKHBQGsKNoBXAxMKdTmw7pSqBYaWcOrp32 pSxBvzwGa+RZzG0Q8ZZvH9/0BAKkn0U+yNj6NkZEUD+Cl5EfKNsYEYwq5GWDVxISjBc/lDb+XbDA BHcTuPQV1T84zJQ6VdCsmPW6AF/ghhmBeC8owH7TzEIK9a5QoNE+xqFx7D+gIIxmOom0jtTYsU0l R+4viMi14QVFwL4Ucd56/Y57fU0IlqUSc/AtyjcndBInTMu2l+nZrghtWjlA3QVHdWpaIbOjGM9O 9y5Xt5hwXsjEeLBi -----END CERTIFICATE----- QuoVadis Root CA ================ -----BEGIN CERTIFICATE----- MIIF0DCCBLigAwIBAgIEOrZQizANBgkqhkiG9w0BAQUFADB/MQswCQYDVQQGEwJCTTEZMBcGA1UE ChMQUXVvVmFkaXMgTGltaXRlZDElMCMGA1UECxMcUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0 eTEuMCwGA1UEAxMlUXVvVmFkaXMgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wMTAz MTkxODMzMzNaFw0yMTAzMTcxODMzMzNaMH8xCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRp cyBMaW1pdGVkMSUwIwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MS4wLAYDVQQD EyVRdW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEF AAOCAQ8AMIIBCgKCAQEAv2G1lVO6V/z68mcLOhrfEYBklbTRvM16z/Ypli4kVEAkOPcahdxYTMuk J0KX0J+DisPkBgNbAKVRHnAEdOLB1Dqr1607BxgFjv2DrOpm2RgbaIr1VxqYuvXtdj182d6UajtL F8HVj71lODqV0D1VNk7feVcxKh7YWWVJWCCYfqtffp/p1k3sg3Spx2zY7ilKhSoGFPlU5tPaZQeL YzcS19Dsw3sgQUSj7cugF+FxZc4dZjH3dgEZyH0DWLaVSR2mEiboxgx24ONmy+pdpibu5cxfvWen AScOospUxbF6lR1xHkopigPcakXBpBlebzbNw6Kwt/5cOOJSvPhEQ+aQuwIDAQABo4ICUjCCAk4w PQYIKwYBBQUHAQEEMTAvMC0GCCsGAQUFBzABhiFodHRwczovL29jc3AucXVvdmFkaXNvZmZzaG9y ZS5jb20wDwYDVR0TAQH/BAUwAwEB/zCCARoGA1UdIASCAREwggENMIIBCQYJKwYBBAG+WAABMIH7 MIHUBggrBgEFBQcCAjCBxxqBxFJlbGlhbmNlIG9uIHRoZSBRdW9WYWRpcyBSb290IENlcnRpZmlj YXRlIGJ5IGFueSBwYXJ0eSBhc3N1bWVzIGFjY2VwdGFuY2Ugb2YgdGhlIHRoZW4gYXBwbGljYWJs ZSBzdGFuZGFyZCB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB1c2UsIGNlcnRpZmljYXRpb24gcHJh Y3RpY2VzLCBhbmQgdGhlIFF1b1ZhZGlzIENlcnRpZmljYXRlIFBvbGljeS4wIgYIKwYBBQUHAgEW Fmh0dHA6Ly93d3cucXVvdmFkaXMuYm0wHQYDVR0OBBYEFItLbe3TKbkGGew5Oanwl4Rqy+/fMIGu BgNVHSMEgaYwgaOAFItLbe3TKbkGGew5Oanwl4Rqy+/foYGEpIGBMH8xCzAJBgNVBAYTAkJNMRkw FwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMSUwIwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0 aG9yaXR5MS4wLAYDVQQDEyVRdW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggQ6 tlCLMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAitQUtf70mpKnGdSkfnIYj9lo fFIk3WdvOXrEql494liwTXCYhGHoG+NpGA7O+0dQoE7/8CQfvbLO9Sf87C9TqnN7Az10buYWnuul LsS/VidQK2K6vkscPFVcQR0kvoIgR13VRH56FmjffU1RcHhXHTMe/QKZnAzNCgVPx7uOpHX6Sm2x gI4JVrmcGmD+XcHXetwReNDWXcG31a0ymQM6isxUJTkxgXsTIlG6Rmyhu576BGxJJnSP0nPrzDCi 5upZIof4l/UO/erMkqQWxFIY6iHOsfHmhIHluqmGKPJDWl0Snawe2ajlCmqnf6CHKc/yiU3U7MXi 5nrQNiOKSnQ2+Q== -----END CERTIFICATE----- QuoVadis Root CA 2 ================== -----BEGIN CERTIFICATE----- MIIFtzCCA5+gAwIBAgICBQkwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0xGTAXBgNVBAoT EFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJvb3QgQ0EgMjAeFw0wNjExMjQx ODI3MDBaFw0zMTExMjQxODIzMzNaMEUxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM aW1pdGVkMRswGQYDVQQDExJRdW9WYWRpcyBSb290IENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4IC DwAwggIKAoICAQCaGMpLlA0ALa8DKYrwD4HIrkwZhR0In6spRIXzL4GtMh6QRr+jhiYaHv5+HBg6 XJxgFyo6dIMzMH1hVBHL7avg5tKifvVrbxi3Cgst/ek+7wrGsxDp3MJGF/hd/aTa/55JWpzmM+Yk lvc/ulsrHHo1wtZn/qtmUIttKGAr79dgw8eTvI02kfN/+NsRE8Scd3bBrrcCaoF6qUWD4gXmuVbB lDePSHFjIuwXZQeVikvfj8ZaCuWw419eaxGrDPmF60Tp+ARz8un+XJiM9XOva7R+zdRcAitMOeGy lZUtQofX1bOQQ7dsE/He3fbE+Ik/0XX1ksOR1YqI0JDs3G3eicJlcZaLDQP9nL9bFqyS2+r+eXyt 66/3FsvbzSUr5R/7mp/iUcw6UwxI5g69ybR2BlLmEROFcmMDBOAENisgGQLodKcftslWZvB1Jdxn wQ5hYIizPtGo/KPaHbDRsSNU30R2be1B2MGyIrZTHN81Hdyhdyox5C315eXbyOD/5YDXC2Og/zOh D7osFRXql7PSorW+8oyWHhqPHWykYTe5hnMz15eWniN9gqRMgeKh0bpnX5UHoycR7hYQe7xFSkyy BNKr79X9DFHOUGoIMfmR2gyPZFwDwzqLID9ujWc9Otb+fVuIyV77zGHcizN300QyNQliBJIWENie J0f7OyHj+OsdWwIDAQABo4GwMIGtMA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMB0GA1Ud DgQWBBQahGK8SEwzJQTU7tD2A8QZRtGUazBuBgNVHSMEZzBlgBQahGK8SEwzJQTU7tD2A8QZRtGU a6FJpEcwRTELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMT ElF1b1ZhZGlzIFJvb3QgQ0EgMoICBQkwDQYJKoZIhvcNAQEFBQADggIBAD4KFk2fBluornFdLwUv Z+YTRYPENvbzwCYMDbVHZF34tHLJRqUDGCdViXh9duqWNIAXINzng/iN/Ae42l9NLmeyhP3ZRPx3 UIHmfLTJDQtyU/h2BwdBR5YM++CCJpNVjP4iH2BlfF/nJrP3MpCYUNQ3cVX2kiF495V5+vgtJodm VjB3pjd4M1IQWK4/YY7yarHvGH5KWWPKjaJW1acvvFYfzznB4vsKqBUsfU16Y8Zsl0Q80m/DShcK +JDSV6IZUaUtl0HaB0+pUNqQjZRG4T7wlP0QADj1O+hA4bRuVhogzG9Yje0uRY/W6ZM/57Es3zrW IozchLsib9D45MY56QSIPMO661V6bYCZJPVsAfv4l7CUW+v90m/xd2gNNWQjrLhVoQPRTUIZ3Ph1 WVaj+ahJefivDrkRoHy3au000LYmYjgahwz46P0u05B/B5EqHdZ+XIWDmbA4CD/pXvk1B+TJYm5X f6dQlfe6yJvmjqIBxdZmv3lh8zwc4bmCXF2gw+nYSL0ZohEUGW6yhhtoPkg3Goi3XZZenMfvJ2II 4pEZXNLxId26F0KCl3GBUzGpn/Z9Yr9y4aOTHcyKJloJONDO1w2AFrR4pTqHTI2KpdVGl/IsELm8 VCLAAVBpQ570su9t+Oza8eOx79+Rj1QqCyXBJhnEUhAFZdWCEOrCMc0u -----END CERTIFICATE----- QuoVadis Root CA 3 ================== -----BEGIN CERTIFICATE----- MIIGnTCCBIWgAwIBAgICBcYwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0xGTAXBgNVBAoT EFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJvb3QgQ0EgMzAeFw0wNjExMjQx OTExMjNaFw0zMTExMjQxOTA2NDRaMEUxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM aW1pdGVkMRswGQYDVQQDExJRdW9WYWRpcyBSb290IENBIDMwggIiMA0GCSqGSIb3DQEBAQUAA4IC DwAwggIKAoICAQDMV0IWVJzmmNPTTe7+7cefQzlKZbPoFog02w1ZkXTPkrgEQK0CSzGrvI2RaNgg DhoB4hp7Thdd4oq3P5kazethq8Jlph+3t723j/z9cI8LoGe+AaJZz3HmDyl2/7FWeUUrH556VOij KTVopAFPD6QuN+8bv+OPEKhyq1hX51SGyMnzW9os2l2ObjyjPtr7guXd8lyyBTNvijbO0BNO/79K DDRMpsMhvVAEVeuxu537RR5kFd5VAYwCdrXLoT9CabwvvWhDFlaJKjdhkf2mrk7AyxRllDdLkgbv BNDInIjbC3uBr7E9KsRlOni27tyAsdLTmZw67mtaa7ONt9XOnMK+pUsvFrGeaDsGb659n/je7Mwp p5ijJUMv7/FfJuGITfhebtfZFG4ZM2mnO4SJk8RTVROhUXhA+LjJou57ulJCg54U7QVSWllWp5f8 nT8KKdjcT5EOE7zelaTfi5m+rJsziO+1ga8bxiJTyPbH7pcUsMV8eFLI8M5ud2CEpukqdiDtWAEX MJPpGovgc2PZapKUSU60rUqFxKMiMPwJ7Wgic6aIDFUhWMXhOp8q3crhkODZc6tsgLjoC2SToJyM Gf+z0gzskSaHirOi4XCPLArlzW1oUevaPwV/izLmE1xr/l9A4iLItLRkT9a6fUg+qGkM17uGcclz uD87nSVL2v9A6wIDAQABo4IBlTCCAZEwDwYDVR0TAQH/BAUwAwEB/zCB4QYDVR0gBIHZMIHWMIHT BgkrBgEEAb5YAAMwgcUwgZMGCCsGAQUFBwICMIGGGoGDQW55IHVzZSBvZiB0aGlzIENlcnRpZmlj YXRlIGNvbnN0aXR1dGVzIGFjY2VwdGFuY2Ugb2YgdGhlIFF1b1ZhZGlzIFJvb3QgQ0EgMyBDZXJ0 aWZpY2F0ZSBQb2xpY3kgLyBDZXJ0aWZpY2F0aW9uIFByYWN0aWNlIFN0YXRlbWVudC4wLQYIKwYB BQUHAgEWIWh0dHA6Ly93d3cucXVvdmFkaXNnbG9iYWwuY29tL2NwczALBgNVHQ8EBAMCAQYwHQYD VR0OBBYEFPLAE+CCQz777i9nMpY1XNu4ywLQMG4GA1UdIwRnMGWAFPLAE+CCQz777i9nMpY1XNu4 ywLQoUmkRzBFMQswCQYDVQQGEwJCTTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDEbMBkGA1UE AxMSUXVvVmFkaXMgUm9vdCBDQSAzggIFxjANBgkqhkiG9w0BAQUFAAOCAgEAT62gLEz6wPJv92ZV qyM07ucp2sNbtrCD2dDQ4iH782CnO11gUyeim/YIIirnv6By5ZwkajGxkHon24QRiSemd1o417+s hvzuXYO8BsbRd2sPbSQvS3pspweWyuOEn62Iix2rFo1bZhfZFvSLgNLd+LJ2w/w4E6oM3kJpK27z POuAJ9v1pkQNn1pVWQvVDVJIxa6f8i+AxeoyUDUSly7B4f/xI4hROJ/yZlZ25w9Rl6VSDE1JUZU2 Pb+iSwwQHYaZTKrzchGT5Or2m9qoXadNt54CrnMAyNojA+j56hl0YgCUyyIgvpSnWbWCar6ZeXqp 8kokUvd0/bpO5qgdAm6xDYBEwa7TIzdfu4V8K5Iu6H6li92Z4b8nby1dqnuH/grdS/yO9SbkbnBC bjPsMZ57k8HkyWkaPcBrTiJt7qtYTcbQQcEr6k8Sh17rRdhs9ZgC06DYVYoGmRmioHfRMJ6szHXu g/WwYjnPbFfiTNKRCw51KBuav/0aQ/HKd/s7j2G4aSgWQgRecCocIdiP4b0jWy10QJLZYxkNc91p vGJHvOB0K7Lrfb5BG7XARsWhIstfTsEokt4YutUqKLsRixeTmJlglFwjz1onl14LBQaTNx47aTbr qZ5hHY8y2o4M1nQ+ewkk2gF3R8Q7zTSMmfXK4SVhM7JZG+Ju1zdXtg2pEto= -----END CERTIFICATE----- Security Communication Root CA ============================== -----BEGIN CERTIFICATE----- MIIDWjCCAkKgAwIBAgIBADANBgkqhkiG9w0BAQUFADBQMQswCQYDVQQGEwJKUDEYMBYGA1UEChMP U0VDT00gVHJ1c3QubmV0MScwJQYDVQQLEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTEw HhcNMDMwOTMwMDQyMDQ5WhcNMjMwOTMwMDQyMDQ5WjBQMQswCQYDVQQGEwJKUDEYMBYGA1UEChMP U0VDT00gVHJ1c3QubmV0MScwJQYDVQQLEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTEw ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCzs/5/022x7xZ8V6UMbXaKL0u/ZPtM7orw 8yl89f/uKuDp6bpbZCKamm8sOiZpUQWZJtzVHGpxxpp9Hp3dfGzGjGdnSj74cbAZJ6kJDKaVv0uM DPpVmDvY6CKhS3E4eayXkmmziX7qIWgGmBSWh9JhNrxtJ1aeV+7AwFb9Ms+k2Y7CI9eNqPPYJayX 5HA49LY6tJ07lyZDo6G8SVlyTCMwhwFY9k6+HGhWZq/NQV3Is00qVUarH9oe4kA92819uZKAnDfd DJZkndwi92SL32HeFZRSFaB9UslLqCHJxrHty8OVYNEP8Ktw+N/LTX7s1vqr2b1/VPKl6Xn62dZ2 JChzAgMBAAGjPzA9MB0GA1UdDgQWBBSgc0mZaNyFW2XjmygvV5+9M7wHSDALBgNVHQ8EBAMCAQYw DwYDVR0TAQH/BAUwAwEB/zANBgkqhkiG9w0BAQUFAAOCAQEAaECpqLvkT115swW1F7NgE+vGkl3g 0dNq/vu+m22/xwVtWSDEHPC32oRYAmP6SBbvT6UL90qY8j+eG61Ha2POCEfrUj94nK9NrvjVT8+a mCoQQTlSxN3Zmw7vkwGusi7KaEIkQmywszo+zenaSMQVy+n5Bw+SUEmK3TGXX8npN6o7WWWXlDLJ s58+OmJYxUmtYg5xpTKqL8aJdkNAExNnPaJUJRDL8Try2frbSVa7pv6nQTXD4IhhyYjH3zYQIphZ 6rBK+1YWc26sTfcioU+tHXotRSflMMFe8toTyyVCUZVHA4xsIcx0Qu1T/zOLjw9XARYvz6buyXAi FL39vmwLAw== -----END CERTIFICATE----- Sonera Class 2 Root CA ====================== -----BEGIN CERTIFICATE----- MIIDIDCCAgigAwIBAgIBHTANBgkqhkiG9w0BAQUFADA5MQswCQYDVQQGEwJGSTEPMA0GA1UEChMG U29uZXJhMRkwFwYDVQQDExBTb25lcmEgQ2xhc3MyIENBMB4XDTAxMDQwNjA3Mjk0MFoXDTIxMDQw NjA3Mjk0MFowOTELMAkGA1UEBhMCRkkxDzANBgNVBAoTBlNvbmVyYTEZMBcGA1UEAxMQU29uZXJh IENsYXNzMiBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAJAXSjWdyvANlsdE+hY3 /Ei9vX+ALTU74W+oZ6m/AxxNjG8yR9VBaKQTBME1DJqEQ/xcHf+Js+gXGM2RX/uJ4+q/Tl18GybT dXnt5oTjV+WtKcT0OijnpXuENmmz/V52vaMtmdOQTiMofRhj8VQ7Jp12W5dCsv+u8E7s3TmVToMG f+dJQMjFAbJUWmYdPfz56TwKnoG4cPABi+QjVHzIrviQHgCWctRUz2EjvOr7nQKV0ba5cTppCD8P tOFCx4j1P5iop7oc4HFx71hXgVB6XGt0Rg6DA5jDjqhu8nYybieDwnPz3BjotJPqdURrBGAgcVeH nfO+oJAjPYok4doh28MCAwEAAaMzMDEwDwYDVR0TAQH/BAUwAwEB/zARBgNVHQ4ECgQISqCqWITT XjwwCwYDVR0PBAQDAgEGMA0GCSqGSIb3DQEBBQUAA4IBAQBazof5FnIVV0sd2ZvnoiYw7JNn39Yt 0jSv9zilzqsWuasvfDXLrNAPtEwr/IDva4yRXzZ299uzGxnq9LIR/WFxRL8oszodv7ND6J+/3DEI cbCdjdY0RzKQxmUk96BKfARzjzlvF4xytb1LyHr4e4PDKE6cCepnP7JnBBvDFNr450kkkdAdavph Oe9r5yF1BgfYErQhIHBCcYHaPJo2vqZbDWpsmh+Re/n570K6Tk6ezAyNlNzZRZxe7EJQY670XcSx EtzKO6gunRRaBXW37Ndj4ro1tgQIkejanZz2ZrUYrAqmVCY0M9IbwdR/GjqOC6oybtv8TyWf2TLH llpwrN9M -----END CERTIFICATE----- Staat der Nederlanden Root CA ============================= -----BEGIN CERTIFICATE----- MIIDujCCAqKgAwIBAgIEAJiWijANBgkqhkiG9w0BAQUFADBVMQswCQYDVQQGEwJOTDEeMBwGA1UE ChMVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSYwJAYDVQQDEx1TdGFhdCBkZXIgTmVkZXJsYW5kZW4g Um9vdCBDQTAeFw0wMjEyMTcwOTIzNDlaFw0xNTEyMTYwOTE1MzhaMFUxCzAJBgNVBAYTAk5MMR4w HAYDVQQKExVTdGFhdCBkZXIgTmVkZXJsYW5kZW4xJjAkBgNVBAMTHVN0YWF0IGRlciBOZWRlcmxh bmRlbiBSb290IENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAmNK1URF6gaYUmHFt vsznExvWJw56s2oYHLZhWtVhCb/ekBPHZ+7d89rFDBKeNVU+LCeIQGv33N0iYfXCxw719tV2U02P jLwYdjeFnejKScfST5gTCaI+Ioicf9byEGW07l8Y1Rfj+MX94p2i71MOhXeiD+EwR+4A5zN9RGca C1Hoi6CeUJhoNFIfLm0B8mBF8jHrqTFoKbt6QZ7GGX+UtFE5A3+y3qcym7RHjm+0Sq7lr7HcsBth vJly3uSJt3omXdozSVtSnA71iq3DuD3oBmrC1SoLbHuEvVYFy4ZlkuxEK7COudxwC0barbxjiDn6 22r+I/q85Ej0ZytqERAhSQIDAQABo4GRMIGOMAwGA1UdEwQFMAMBAf8wTwYDVR0gBEgwRjBEBgRV HSAAMDwwOgYIKwYBBQUHAgEWLmh0dHA6Ly93d3cucGtpb3ZlcmhlaWQubmwvcG9saWNpZXMvcm9v dC1wb2xpY3kwDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBSofeu8Y6R0E3QA7Jbg0zTBLL9s+DAN BgkqhkiG9w0BAQUFAAOCAQEABYSHVXQ2YcG70dTGFagTtJ+k/rvuFbQvBgwp8qiSpGEN/KtcCFtR EytNwiphyPgJWPwtArI5fZlmgb9uXJVFIGzmeafR2Bwp/MIgJ1HI8XxdNGdphREwxgDS1/PTfLbw MVcoEoJz6TMvplW0C5GUR5z6u3pCMuiufi3IvKwUv9kP2Vv8wfl6leF9fpb8cbDCTMjfRTTJzg3y nGQI0DvDKcWy7ZAEwbEpkcUwb8GpcjPM/l0WFywRaed+/sWDCN+83CI6LiBpIzlWYGeQiy52OfsR iJf2fL1LuCAWZwWN4jvBcj+UlTfHXbme2JOhF4//DGYVwSR8MnwDHTuhWEUykw== -----END CERTIFICATE----- TDC Internet Root CA ==================== -----BEGIN CERTIFICATE----- MIIEKzCCAxOgAwIBAgIEOsylTDANBgkqhkiG9w0BAQUFADBDMQswCQYDVQQGEwJESzEVMBMGA1UE ChMMVERDIEludGVybmV0MR0wGwYDVQQLExRUREMgSW50ZXJuZXQgUm9vdCBDQTAeFw0wMTA0MDUx NjMzMTdaFw0yMTA0MDUxNzAzMTdaMEMxCzAJBgNVBAYTAkRLMRUwEwYDVQQKEwxUREMgSW50ZXJu ZXQxHTAbBgNVBAsTFFREQyBJbnRlcm5ldCBSb290IENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A MIIBCgKCAQEAxLhAvJHVYx/XmaCLDEAedLdInUaMArLgJF/wGROnN4NrXceO+YQwzho7+vvOi20j xsNuZp+Jpd/gQlBn+h9sHvTQBda/ytZO5GhgbEaqHF1j4QeGDmUApy6mcca8uYGoOn0a0vnRrEvL znWv3Hv6gXPU/Lq9QYjUdLP5Xjg6PEOo0pVOd20TDJ2PeAG3WiAfAzc14izbSysseLlJ28TQx5yc 5IogCSEWVmb/Bexb4/DPqyQkXsN/cHoSxNK1EKC2IeGNeGlVRGn1ypYcNIUXJXfi9i8nmHj9eQY6 otZaQ8H/7AQ77hPv01ha/5Lr7K7a8jcDR0G2l8ktCkEiu7vmpwIDAQABo4IBJTCCASEwEQYJYIZI AYb4QgEBBAQDAgAHMGUGA1UdHwReMFwwWqBYoFakVDBSMQswCQYDVQQGEwJESzEVMBMGA1UEChMM VERDIEludGVybmV0MR0wGwYDVQQLExRUREMgSW50ZXJuZXQgUm9vdCBDQTENMAsGA1UEAxMEQ1JM MTArBgNVHRAEJDAigA8yMDAxMDQwNTE2MzMxN1qBDzIwMjEwNDA1MTcwMzE3WjALBgNVHQ8EBAMC AQYwHwYDVR0jBBgwFoAUbGQBx/2FbazI2p5QCIUItTxWqFAwHQYDVR0OBBYEFGxkAcf9hW2syNqe UAiFCLU8VqhQMAwGA1UdEwQFMAMBAf8wHQYJKoZIhvZ9B0EABBAwDhsIVjUuMDo0LjADAgSQMA0G CSqGSIb3DQEBBQUAA4IBAQBOQ8zR3R0QGwZ/t6T609lN+yOfI1Rb5osvBCiLtSdtiaHsmGnc540m gwV5dOy0uaOXwTUA/RXaOYE6lTGQ3pfphqiZdwzlWqCE/xIWrG64jcN7ksKsLtB9KOy282A4aW8+ 2ARVPp7MVdK6/rtHBNcK2RYKNCn1WBPVT8+PVkuzHu7TmHnaCB4Mb7j4Fifvwm899qNLPg7kbWzb O0ESm70NRyN/PErQr8Cv9u8btRXE64PECV90i9kR+8JWsTz4cMo0jUNAE4z9mQNUecYu6oah9jrU Cbz0vGbMPVjQV0kK7iXiQe4T+Zs4NNEA9X7nlB38aQNiuJkFBT1reBK9sG9l -----END CERTIFICATE----- UTN DATACorp SGC Root CA ======================== -----BEGIN CERTIFICATE----- MIIEXjCCA0agAwIBAgIQRL4Mi1AAIbQR0ypoBqmtaTANBgkqhkiG9w0BAQUFADCBkzELMAkGA1UE BhMCVVMxCzAJBgNVBAgTAlVUMRcwFQYDVQQHEw5TYWx0IExha2UgQ2l0eTEeMBwGA1UEChMVVGhl IFVTRVJUUlVTVCBOZXR3b3JrMSEwHwYDVQQLExhodHRwOi8vd3d3LnVzZXJ0cnVzdC5jb20xGzAZ BgNVBAMTElVUTiAtIERBVEFDb3JwIFNHQzAeFw05OTA2MjQxODU3MjFaFw0xOTA2MjQxOTA2MzBa MIGTMQswCQYDVQQGEwJVUzELMAkGA1UECBMCVVQxFzAVBgNVBAcTDlNhbHQgTGFrZSBDaXR5MR4w HAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxITAfBgNVBAsTGGh0dHA6Ly93d3cudXNlcnRy dXN0LmNvbTEbMBkGA1UEAxMSVVROIC0gREFUQUNvcnAgU0dDMIIBIjANBgkqhkiG9w0BAQEFAAOC AQ8AMIIBCgKCAQEA3+5YEKIrblXEjr8uRgnn4AgPLit6E5Qbvfa2gI5lBZMAHryv4g+OGQ0SR+ys raP6LnD43m77VkIVni5c7yPeIbkFdicZD0/Ww5y0vpQZY/KmEQrrU0icvvIpOxboGqBMpsn0GFlo wHDyUwDAXlCCpVZvNvlK4ESGoE1O1kduSUrLZ9emxAW5jh70/P/N5zbgnAVssjMiFdC04MwXwLLA 9P4yPykqlXvY8qdOD1R8oQ2AswkDwf9c3V6aPryuvEeKaq5xyh+xKrhfQgUL7EYw0XILyulWbfXv 33i+Ybqypa4ETLyorGkVl73v67SMvzX41MPRKA5cOp9wGDMgd8SirwIDAQABo4GrMIGoMAsGA1Ud DwQEAwIBxjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRTMtGzz3/64PGgXYVOktKeRR20TzA9 BgNVHR8ENjA0MDKgMKAuhixodHRwOi8vY3JsLnVzZXJ0cnVzdC5jb20vVVROLURBVEFDb3JwU0dD LmNybDAqBgNVHSUEIzAhBggrBgEFBQcDAQYKKwYBBAGCNwoDAwYJYIZIAYb4QgQBMA0GCSqGSIb3 DQEBBQUAA4IBAQAnNZcAiosovcYzMB4p/OL31ZjUQLtgyr+rFywJNn9Q+kHcrpY6CiM+iVnJowft Gzet/Hy+UUla3joKVAgWRcKZsYfNjGjgaQPpxE6YsjuMFrMOoAyYUJuTqXAJyCyjj98C5OBxOvG0 I3KgqgHf35g+FFCgMSa9KOlaMCZ1+XtgHI3zzVAmbQQnmt/VDUVHKWss5nbZqSl9Mt3JNjy9rjXx EZ4du5A/EkdOjtd+D2JzHVImOBwYSf0wdJrE5SIv2MCN7ZF6TACPcn9d2t0bi0Vr591pl6jFVkwP DPafepE39peC4N1xaf92P2BNPM/3mfnGV/TJVTl4uix5yaaIK/QI -----END CERTIFICATE----- UTN USERFirst Hardware Root CA ============================== -----BEGIN CERTIFICATE----- MIIEdDCCA1ygAwIBAgIQRL4Mi1AAJLQR0zYq/mUK/TANBgkqhkiG9w0BAQUFADCBlzELMAkGA1UE BhMCVVMxCzAJBgNVBAgTAlVUMRcwFQYDVQQHEw5TYWx0IExha2UgQ2l0eTEeMBwGA1UEChMVVGhl IFVTRVJUUlVTVCBOZXR3b3JrMSEwHwYDVQQLExhodHRwOi8vd3d3LnVzZXJ0cnVzdC5jb20xHzAd BgNVBAMTFlVUTi1VU0VSRmlyc3QtSGFyZHdhcmUwHhcNOTkwNzA5MTgxMDQyWhcNMTkwNzA5MTgx OTIyWjCBlzELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAlVUMRcwFQYDVQQHEw5TYWx0IExha2UgQ2l0 eTEeMBwGA1UEChMVVGhlIFVTRVJUUlVTVCBOZXR3b3JrMSEwHwYDVQQLExhodHRwOi8vd3d3LnVz ZXJ0cnVzdC5jb20xHzAdBgNVBAMTFlVUTi1VU0VSRmlyc3QtSGFyZHdhcmUwggEiMA0GCSqGSIb3 DQEBAQUAA4IBDwAwggEKAoIBAQCx98M4P7Sof885glFn0G2f0v9Y8+efK+wNiVSZuTiZFvfgIXlI wrthdBKWHTxqctU8EGc6Oe0rE81m65UJM6Rsl7HoxuzBdXmcRl6Nq9Bq/bkqVRcQVLMZ8Jr28bFd tqdt++BxF2uiiPsA3/4aMXcMmgF6sTLjKwEHOG7DpV4jvEWbe1DByTCP2+UretNb+zNAHqDVmBe8 i4fDidNdoI6yqqr2jmmIBsX6iSHzCJ1pLgkzmykNRg+MzEk0sGlRvfkGzWitZky8PqxhvQqIDsjf Pe58BEydCl5rkdbux+0ojatNh4lz0G6k0B4WixThdkQDf2Os5M1JnMWS9KsyoUhbAgMBAAGjgbkw gbYwCwYDVR0PBAQDAgHGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFKFyXyYbKJhDlV0HN9WF lp1L0sNFMEQGA1UdHwQ9MDswOaA3oDWGM2h0dHA6Ly9jcmwudXNlcnRydXN0LmNvbS9VVE4tVVNF UkZpcnN0LUhhcmR3YXJlLmNybDAxBgNVHSUEKjAoBggrBgEFBQcDAQYIKwYBBQUHAwUGCCsGAQUF BwMGBggrBgEFBQcDBzANBgkqhkiG9w0BAQUFAAOCAQEARxkP3nTGmZev/K0oXnWO6y1n7k57K9cM //bey1WiCuFMVGWTYGufEpytXoMs61quwOQt9ABjHbjAbPLPSbtNk28GpgoiskliCE7/yMgUsogW XecB5BKV5UU0s4tpvc+0hY91UZ59Ojg6FEgSxvunOxqNDYJAB+gECJChicsZUN/KHAG8HQQZexB2 lzvukJDKxA4fFm517zP4029bHpbj4HR3dHuKom4t3XbWOTCC8KucUvIqx69JXn7HaOWCgchqJ/kn iCrVWFCVH/A7HFe7fRQ5YiuayZSSKqMiDP+JJn1fIytH1xUdqWqeUQ0qUZ6B+dQ7XnASfxAynB67 nfhmqA== -----END CERTIFICATE----- Camerfirma Chambers of Commerce Root ==================================== -----BEGIN CERTIFICATE----- MIIEvTCCA6WgAwIBAgIBADANBgkqhkiG9w0BAQUFADB/MQswCQYDVQQGEwJFVTEnMCUGA1UEChMe QUMgQ2FtZXJmaXJtYSBTQSBDSUYgQTgyNzQzMjg3MSMwIQYDVQQLExpodHRwOi8vd3d3LmNoYW1i ZXJzaWduLm9yZzEiMCAGA1UEAxMZQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdDAeFw0wMzA5MzAx NjEzNDNaFw0zNzA5MzAxNjEzNDRaMH8xCzAJBgNVBAYTAkVVMScwJQYDVQQKEx5BQyBDYW1lcmZp cm1hIFNBIENJRiBBODI3NDMyODcxIzAhBgNVBAsTGmh0dHA6Ly93d3cuY2hhbWJlcnNpZ24ub3Jn MSIwIAYDVQQDExlDaGFtYmVycyBvZiBDb21tZXJjZSBSb290MIIBIDANBgkqhkiG9w0BAQEFAAOC AQ0AMIIBCAKCAQEAtzZV5aVdGDDg2olUkfzIx1L4L1DZ77F1c2VHfRtbunXF/KGIJPov7coISjlU xFF6tdpg6jg8gbLL8bvZkSM/SAFwdakFKq0fcfPJVD0dBmpAPrMMhe5cG3nCYsS4No41XQEMIwRH NaqbYE6gZj3LJgqcQKH0XZi/caulAGgq7YN6D6IUtdQis4CwPAxaUWktWBiP7Zme8a7ileb2R6jW DA+wWFjbw2Y3npuRVDM30pQcakjJyfKl2qUMI/cjDpwyVV5xnIQFUZot/eZOKjRa3spAN2cMVCFV d9oKDMyXroDclDZK9D7ONhMeU+SsTjoF7Nuucpw4i9A5O4kKPnf+dQIBA6OCAUQwggFAMBIGA1Ud EwEB/wQIMAYBAf8CAQwwPAYDVR0fBDUwMzAxoC+gLYYraHR0cDovL2NybC5jaGFtYmVyc2lnbi5v cmcvY2hhbWJlcnNyb290LmNybDAdBgNVHQ4EFgQU45T1sU3p26EpW1eLTXYGduHRooowDgYDVR0P AQH/BAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIABzAnBgNVHREEIDAegRxjaGFtYmVyc3Jvb3RAY2hh bWJlcnNpZ24ub3JnMCcGA1UdEgQgMB6BHGNoYW1iZXJzcm9vdEBjaGFtYmVyc2lnbi5vcmcwWAYD VR0gBFEwTzBNBgsrBgEEAYGHLgoDATA+MDwGCCsGAQUFBwIBFjBodHRwOi8vY3BzLmNoYW1iZXJz aWduLm9yZy9jcHMvY2hhbWJlcnNyb290Lmh0bWwwDQYJKoZIhvcNAQEFBQADggEBAAxBl8IahsAi fJ/7kPMa0QOx7xP5IV8EnNrJpY0nbJaHkb5BkAFyk+cefV/2icZdp0AJPaxJRUXcLo0waLIJuvvD L8y6C98/d3tGfToSJI6WjzwFCm/SlCgdbQzALogi1djPHRPH8EjX1wWnz8dHnjs8NMiAT9QUu/wN UPf6s+xCX6ndbcj0dc97wXImsQEcXCz9ek60AcUFV7nnPKoF2YjpB0ZBzu9Bga5Y34OirsrXdx/n ADydb47kMgkdTXg0eDQ8lJsm7U9xxhl6vSAiSFr+S30Dt+dYvsYyTnQeaN2oaFuzPu5ifdmA6Ap1 erfutGWaIZDgqtCYvDi1czyL+Nw= -----END CERTIFICATE----- Camerfirma Global Chambersign Root ================================== -----BEGIN CERTIFICATE----- MIIExTCCA62gAwIBAgIBADANBgkqhkiG9w0BAQUFADB9MQswCQYDVQQGEwJFVTEnMCUGA1UEChMe QUMgQ2FtZXJmaXJtYSBTQSBDSUYgQTgyNzQzMjg3MSMwIQYDVQQLExpodHRwOi8vd3d3LmNoYW1i ZXJzaWduLm9yZzEgMB4GA1UEAxMXR2xvYmFsIENoYW1iZXJzaWduIFJvb3QwHhcNMDMwOTMwMTYx NDE4WhcNMzcwOTMwMTYxNDE4WjB9MQswCQYDVQQGEwJFVTEnMCUGA1UEChMeQUMgQ2FtZXJmaXJt YSBTQSBDSUYgQTgyNzQzMjg3MSMwIQYDVQQLExpodHRwOi8vd3d3LmNoYW1iZXJzaWduLm9yZzEg MB4GA1UEAxMXR2xvYmFsIENoYW1iZXJzaWduIFJvb3QwggEgMA0GCSqGSIb3DQEBAQUAA4IBDQAw ggEIAoIBAQCicKLQn0KuWxfH2H3PFIP8T8mhtxOviteePgQKkotgVvq0Mi+ITaFgCPS3CU6gSS9J 1tPfnZdan5QEcOw/Wdm3zGaLmFIoCQLfxS+EjXqXd7/sQJ0lcqu1PzKY+7e3/HKE5TWH+VX6ox8O by4o3Wmg2UIQxvi1RMLQQ3/bvOSiPGpVeAp3qdjqGTK3L/5cPxvusZjsyq16aUXjlg9V9ubtdepl 6DJWk0aJqCWKZQbua795B9Dxt6/tLE2Su8CoX6dnfQTyFQhwrJLWfQTSM/tMtgsL+xrJxI0DqX5c 8lCrEqWhz0hQpe/SyBoT+rB/sYIcd2oPX9wLlY/vQ37mRQklAgEDo4IBUDCCAUwwEgYDVR0TAQH/ BAgwBgEB/wIBDDA/BgNVHR8EODA2MDSgMqAwhi5odHRwOi8vY3JsLmNoYW1iZXJzaWduLm9yZy9j aGFtYmVyc2lnbnJvb3QuY3JsMB0GA1UdDgQWBBRDnDafsJ4wTcbOX60Qq+UDpfqpFDAOBgNVHQ8B Af8EBAMCAQYwEQYJYIZIAYb4QgEBBAQDAgAHMCoGA1UdEQQjMCGBH2NoYW1iZXJzaWducm9vdEBj aGFtYmVyc2lnbi5vcmcwKgYDVR0SBCMwIYEfY2hhbWJlcnNpZ25yb290QGNoYW1iZXJzaWduLm9y ZzBbBgNVHSAEVDBSMFAGCysGAQQBgYcuCgEBMEEwPwYIKwYBBQUHAgEWM2h0dHA6Ly9jcHMuY2hh bWJlcnNpZ24ub3JnL2Nwcy9jaGFtYmVyc2lnbnJvb3QuaHRtbDANBgkqhkiG9w0BAQUFAAOCAQEA PDtwkfkEVCeR4e3t/mh/YV3lQWVPMvEYBZRqHN4fcNs+ezICNLUMbKGKfKX0j//U2K0X1S0E0T9Y gOKBWYi+wONGkyT+kL0mojAt6JcmVzWJdJYY9hXiryQZVgICsroPFOrGimbBhkVVi76SvpykBMdJ PJ7oKXqJ1/6v/2j1pReQvayZzKWGVwlnRtvWFsJG8eSpUPWP0ZIV018+xgBJOm5YstHRJw0lyDL4 IBHNfTIzSJRUTN3cecQwn+uOuFW114hcxWokPbLTBQNRxgfvzBRydD1ucs4YKIxKoHflCStFREes t2d/AYoFWpO+ocH/+OcOZ6RHSXZddZAa9SaP8A== -----END CERTIFICATE----- NetLock Notary (Class A) Root ============================= -----BEGIN CERTIFICATE----- MIIGfTCCBWWgAwIBAgICAQMwDQYJKoZIhvcNAQEEBQAwga8xCzAJBgNVBAYTAkhVMRAwDgYDVQQI EwdIdW5nYXJ5MREwDwYDVQQHEwhCdWRhcGVzdDEnMCUGA1UEChMeTmV0TG9jayBIYWxvemF0Yml6 dG9uc2FnaSBLZnQuMRowGAYDVQQLExFUYW51c2l0dmFueWtpYWRvazE2MDQGA1UEAxMtTmV0TG9j ayBLb3pqZWd5em9pIChDbGFzcyBBKSBUYW51c2l0dmFueWtpYWRvMB4XDTk5MDIyNDIzMTQ0N1oX DTE5MDIxOTIzMTQ0N1owga8xCzAJBgNVBAYTAkhVMRAwDgYDVQQIEwdIdW5nYXJ5MREwDwYDVQQH EwhCdWRhcGVzdDEnMCUGA1UEChMeTmV0TG9jayBIYWxvemF0Yml6dG9uc2FnaSBLZnQuMRowGAYD VQQLExFUYW51c2l0dmFueWtpYWRvazE2MDQGA1UEAxMtTmV0TG9jayBLb3pqZWd5em9pIChDbGFz cyBBKSBUYW51c2l0dmFueWtpYWRvMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAvHSM D7tM9DceqQWC2ObhbHDqeLVu0ThEDaiDzl3S1tWBxdRL51uUcCbbO51qTGL3cfNk1mE7PetzozfZ z+qMkjvN9wfcZnSX9EUi3fRc4L9t875lM+QVOr/bmJBVOMTtplVjC7B4BPTjbsE/jvxReB+SnoPC /tmwqcm8WgD/qaiYdPv2LD4VOQ22BFWoDpggQrOxJa1+mm9dU7GrDPzr4PN6s6iz/0b2Y6LYOph7 tqyF/7AlT3Rj5xMHpQqPBffAZG9+pyeAlt7ULoZgx2srXnN7F+eRP2QM2EsiNCubMvJIH5+hCoR6 4sKtlz2O1cH5VqNQ6ca0+pii7pXmKgOM3wIDAQABo4ICnzCCApswDgYDVR0PAQH/BAQDAgAGMBIG A1UdEwEB/wQIMAYBAf8CAQQwEQYJYIZIAYb4QgEBBAQDAgAHMIICYAYJYIZIAYb4QgENBIICURaC Ak1GSUdZRUxFTSEgRXplbiB0YW51c2l0dmFueSBhIE5ldExvY2sgS2Z0LiBBbHRhbGFub3MgU3pv bGdhbHRhdGFzaSBGZWx0ZXRlbGVpYmVuIGxlaXJ0IGVsamFyYXNvayBhbGFwamFuIGtlc3p1bHQu IEEgaGl0ZWxlc2l0ZXMgZm9seWFtYXRhdCBhIE5ldExvY2sgS2Z0LiB0ZXJtZWtmZWxlbG9zc2Vn LWJpenRvc2l0YXNhIHZlZGkuIEEgZGlnaXRhbGlzIGFsYWlyYXMgZWxmb2dhZGFzYW5hayBmZWx0 ZXRlbGUgYXogZWxvaXJ0IGVsbGVub3J6ZXNpIGVsamFyYXMgbWVndGV0ZWxlLiBBeiBlbGphcmFz IGxlaXJhc2EgbWVndGFsYWxoYXRvIGEgTmV0TG9jayBLZnQuIEludGVybmV0IGhvbmxhcGphbiBh IGh0dHBzOi8vd3d3Lm5ldGxvY2submV0L2RvY3MgY2ltZW4gdmFneSBrZXJoZXRvIGF6IGVsbGVu b3J6ZXNAbmV0bG9jay5uZXQgZS1tYWlsIGNpbWVuLiBJTVBPUlRBTlQhIFRoZSBpc3N1YW5jZSBh bmQgdGhlIHVzZSBvZiB0aGlzIGNlcnRpZmljYXRlIGlzIHN1YmplY3QgdG8gdGhlIE5ldExvY2sg Q1BTIGF2YWlsYWJsZSBhdCBodHRwczovL3d3dy5uZXRsb2NrLm5ldC9kb2NzIG9yIGJ5IGUtbWFp bCBhdCBjcHNAbmV0bG9jay5uZXQuMA0GCSqGSIb3DQEBBAUAA4IBAQBIJEb3ulZv+sgoA0BO5TE5 ayZrU3/b39/zcT0mwBQOxmd7I6gMc90Bu8bKbjc5VdXHjFYgDigKDtIqpLBJUsY4B/6+CgmM0ZjP ytoUMaFP0jn8DxEsQ8Pdq5PHVT5HfBgaANzze9jyf1JsIPQLX2lS9O74silg6+NJMSEN1rUQQeJB CWziGppWS3cC9qCbmieH6FUpccKQn0V4GuEVZD3QDtigdp+uxdAu6tYPVuxkf1qbFFgBJ34TUMdr KuZoPL9coAob4Q566eKAw+np9v1sEZ7Q5SgnK1QyQhSCdeZK8CtmdWOMovsEPoMOmzbwGOQmIMOM 8CgHrTwXZoi1/baI -----END CERTIFICATE----- NetLock Business (Class B) Root =============================== -----BEGIN CERTIFICATE----- MIIFSzCCBLSgAwIBAgIBaTANBgkqhkiG9w0BAQQFADCBmTELMAkGA1UEBhMCSFUxETAPBgNVBAcT CEJ1ZGFwZXN0MScwJQYDVQQKEx5OZXRMb2NrIEhhbG96YXRiaXp0b25zYWdpIEtmdC4xGjAYBgNV BAsTEVRhbnVzaXR2YW55a2lhZG9rMTIwMAYDVQQDEylOZXRMb2NrIFV6bGV0aSAoQ2xhc3MgQikg VGFudXNpdHZhbnlraWFkbzAeFw05OTAyMjUxNDEwMjJaFw0xOTAyMjAxNDEwMjJaMIGZMQswCQYD VQQGEwJIVTERMA8GA1UEBxMIQnVkYXBlc3QxJzAlBgNVBAoTHk5ldExvY2sgSGFsb3phdGJpenRv bnNhZ2kgS2Z0LjEaMBgGA1UECxMRVGFudXNpdHZhbnlraWFkb2sxMjAwBgNVBAMTKU5ldExvY2sg VXpsZXRpIChDbGFzcyBCKSBUYW51c2l0dmFueWtpYWRvMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCB iQKBgQCx6gTsIKAjwo84YM/HRrPVG/77uZmeBNwcf4xKgZjupNTKihe5In+DCnVMm8Bp2GQ5o+2S o/1bXHQawEfKOml2mrriRBf8TKPV/riXiK+IA4kfpPIEPsgHC+b5sy96YhQJRhTKZPWLgLViqNhr 1nGTLbO/CVRY7QbrqHvcQ7GhaQIDAQABo4ICnzCCApswEgYDVR0TAQH/BAgwBgEB/wIBBDAOBgNV HQ8BAf8EBAMCAAYwEQYJYIZIAYb4QgEBBAQDAgAHMIICYAYJYIZIAYb4QgENBIICURaCAk1GSUdZ RUxFTSEgRXplbiB0YW51c2l0dmFueSBhIE5ldExvY2sgS2Z0LiBBbHRhbGFub3MgU3pvbGdhbHRh dGFzaSBGZWx0ZXRlbGVpYmVuIGxlaXJ0IGVsamFyYXNvayBhbGFwamFuIGtlc3p1bHQuIEEgaGl0 ZWxlc2l0ZXMgZm9seWFtYXRhdCBhIE5ldExvY2sgS2Z0LiB0ZXJtZWtmZWxlbG9zc2VnLWJpenRv c2l0YXNhIHZlZGkuIEEgZGlnaXRhbGlzIGFsYWlyYXMgZWxmb2dhZGFzYW5hayBmZWx0ZXRlbGUg YXogZWxvaXJ0IGVsbGVub3J6ZXNpIGVsamFyYXMgbWVndGV0ZWxlLiBBeiBlbGphcmFzIGxlaXJh c2EgbWVndGFsYWxoYXRvIGEgTmV0TG9jayBLZnQuIEludGVybmV0IGhvbmxhcGphbiBhIGh0dHBz Oi8vd3d3Lm5ldGxvY2submV0L2RvY3MgY2ltZW4gdmFneSBrZXJoZXRvIGF6IGVsbGVub3J6ZXNA bmV0bG9jay5uZXQgZS1tYWlsIGNpbWVuLiBJTVBPUlRBTlQhIFRoZSBpc3N1YW5jZSBhbmQgdGhl IHVzZSBvZiB0aGlzIGNlcnRpZmljYXRlIGlzIHN1YmplY3QgdG8gdGhlIE5ldExvY2sgQ1BTIGF2 YWlsYWJsZSBhdCBodHRwczovL3d3dy5uZXRsb2NrLm5ldC9kb2NzIG9yIGJ5IGUtbWFpbCBhdCBj cHNAbmV0bG9jay5uZXQuMA0GCSqGSIb3DQEBBAUAA4GBAATbrowXr/gOkDFOzT4JwG06sPgzTEdM 43WIEJessDgVkcYplswhwG08pXTP2IKlOcNl40JwuyKQ433bNXbhoLXan3BukxowOR0w2y7jfLKR stE3Kfq51hdcR0/jHTjrn9V7lagonhVK0dHQKwCXoOKSNitjrFgBazMpUIaD8QFI -----END CERTIFICATE----- NetLock Express (Class C) Root ============================== -----BEGIN CERTIFICATE----- MIIFTzCCBLigAwIBAgIBaDANBgkqhkiG9w0BAQQFADCBmzELMAkGA1UEBhMCSFUxETAPBgNVBAcT CEJ1ZGFwZXN0MScwJQYDVQQKEx5OZXRMb2NrIEhhbG96YXRiaXp0b25zYWdpIEtmdC4xGjAYBgNV BAsTEVRhbnVzaXR2YW55a2lhZG9rMTQwMgYDVQQDEytOZXRMb2NrIEV4cHJlc3N6IChDbGFzcyBD KSBUYW51c2l0dmFueWtpYWRvMB4XDTk5MDIyNTE0MDgxMVoXDTE5MDIyMDE0MDgxMVowgZsxCzAJ BgNVBAYTAkhVMREwDwYDVQQHEwhCdWRhcGVzdDEnMCUGA1UEChMeTmV0TG9jayBIYWxvemF0Yml6 dG9uc2FnaSBLZnQuMRowGAYDVQQLExFUYW51c2l0dmFueWtpYWRvazE0MDIGA1UEAxMrTmV0TG9j ayBFeHByZXNzeiAoQ2xhc3MgQykgVGFudXNpdHZhbnlraWFkbzCBnzANBgkqhkiG9w0BAQEFAAOB jQAwgYkCgYEA6+ywbGGKIyWvYCDj2Z/8kwvbXY2wobNAOoLO/XXgeDIDhlqGlZHtU/qdQPzm6N3Z W3oDvV3zOwzDUXmbrVWg6dADEK8KuhRC2VImESLH0iDMgqSaqf64gXadarfSNnU+sYYJ9m5tfk63 euyucYT2BDMIJTLrdKwWRMbkQJMdf60CAwEAAaOCAp8wggKbMBIGA1UdEwEB/wQIMAYBAf8CAQQw DgYDVR0PAQH/BAQDAgAGMBEGCWCGSAGG+EIBAQQEAwIABzCCAmAGCWCGSAGG+EIBDQSCAlEWggJN RklHWUVMRU0hIEV6ZW4gdGFudXNpdHZhbnkgYSBOZXRMb2NrIEtmdC4gQWx0YWxhbm9zIFN6b2xn YWx0YXRhc2kgRmVsdGV0ZWxlaWJlbiBsZWlydCBlbGphcmFzb2sgYWxhcGphbiBrZXN6dWx0LiBB IGhpdGVsZXNpdGVzIGZvbHlhbWF0YXQgYSBOZXRMb2NrIEtmdC4gdGVybWVrZmVsZWxvc3NlZy1i aXp0b3NpdGFzYSB2ZWRpLiBBIGRpZ2l0YWxpcyBhbGFpcmFzIGVsZm9nYWRhc2FuYWsgZmVsdGV0 ZWxlIGF6IGVsb2lydCBlbGxlbm9yemVzaSBlbGphcmFzIG1lZ3RldGVsZS4gQXogZWxqYXJhcyBs ZWlyYXNhIG1lZ3RhbGFsaGF0byBhIE5ldExvY2sgS2Z0LiBJbnRlcm5ldCBob25sYXBqYW4gYSBo dHRwczovL3d3dy5uZXRsb2NrLm5ldC9kb2NzIGNpbWVuIHZhZ3kga2VyaGV0byBheiBlbGxlbm9y emVzQG5ldGxvY2submV0IGUtbWFpbCBjaW1lbi4gSU1QT1JUQU5UISBUaGUgaXNzdWFuY2UgYW5k IHRoZSB1c2Ugb2YgdGhpcyBjZXJ0aWZpY2F0ZSBpcyBzdWJqZWN0IHRvIHRoZSBOZXRMb2NrIENQ UyBhdmFpbGFibGUgYXQgaHR0cHM6Ly93d3cubmV0bG9jay5uZXQvZG9jcyBvciBieSBlLW1haWwg YXQgY3BzQG5ldGxvY2submV0LjANBgkqhkiG9w0BAQQFAAOBgQAQrX/XDDKACtiG8XmYta3UzbM2 xJZIwVzNmtkFLp++UOv0JhQQLdRmF/iewSf98e3ke0ugbLWrmldwpu2gpO0u9f38vf5NNwgMvOOW gyL1SRt/Syu0VMGAfJlOHdCM7tCs5ZL6dVb+ZKATj7i4Fp1hBWeAyNDYpQcCNJgEjTME1A== -----END CERTIFICATE----- XRamp Global CA Root ==================== -----BEGIN CERTIFICATE----- MIIEMDCCAxigAwIBAgIQUJRs7Bjq1ZxN1ZfvdY+grTANBgkqhkiG9w0BAQUFADCBgjELMAkGA1UE BhMCVVMxHjAcBgNVBAsTFXd3dy54cmFtcHNlY3VyaXR5LmNvbTEkMCIGA1UEChMbWFJhbXAgU2Vj dXJpdHkgU2VydmljZXMgSW5jMS0wKwYDVQQDEyRYUmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBB dXRob3JpdHkwHhcNMDQxMTAxMTcxNDA0WhcNMzUwMTAxMDUzNzE5WjCBgjELMAkGA1UEBhMCVVMx HjAcBgNVBAsTFXd3dy54cmFtcHNlY3VyaXR5LmNvbTEkMCIGA1UEChMbWFJhbXAgU2VjdXJpdHkg U2VydmljZXMgSW5jMS0wKwYDVQQDEyRYUmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBBdXRob3Jp dHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCYJB69FbS638eMpSe2OAtp87ZOqCwu IR1cRN8hXX4jdP5efrRKt6atH67gBhbim1vZZ3RrXYCPKZ2GG9mcDZhtdhAoWORlsH9KmHmf4MMx foArtYzAQDsRhtDLooY2YKTVMIJt2W7QDxIEM5dfT2Fa8OT5kavnHTu86M/0ay00fOJIYRyO82FE zG+gSqmUsE3a56k0enI4qEHMPJQRfevIpoy3hsvKMzvZPTeL+3o+hiznc9cKV6xkmxnr9A8ECIqs AxcZZPRaJSKNNCyy9mgdEm3Tih4U2sSPpuIjhdV6Db1q4Ons7Be7QhtnqiXtRYMh/MHJfNViPvry xS3T/dRlAgMBAAGjgZ8wgZwwEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0PBAQDAgGGMA8GA1Ud EwEB/wQFMAMBAf8wHQYDVR0OBBYEFMZPoj0GY4QJnM5i5ASsjVy16bYbMDYGA1UdHwQvMC0wK6Ap oCeGJWh0dHA6Ly9jcmwueHJhbXBzZWN1cml0eS5jb20vWEdDQS5jcmwwEAYJKwYBBAGCNxUBBAMC AQEwDQYJKoZIhvcNAQEFBQADggEBAJEVOQMBG2f7Shz5CmBbodpNl2L5JFMn14JkTpAuw0kbK5rc /Kh4ZzXxHfARvbdI4xD2Dd8/0sm2qlWkSLoC295ZLhVbO50WfUfXN+pfTXYSNrsf16GBBEYgoyxt qZ4Bfj8pzgCT3/3JknOJiWSe5yvkHJEs0rnOfc5vMZnT5r7SHpDwCRR5XCOrTdLaIR9NmXmd4c8n nxCbHIgNsIpkQTG4DmyQJKSbXHGPurt+HBvbaoAPIbzp26a3QPSyi6mx5O+aGtA9aZnuqCij4Tyz 8LIRnM98QObd50N9otg6tamN8jSZxNQQ4Qb9CYQQO+7ETPTsJ3xCwnR8gooJybQDJbw= -----END CERTIFICATE----- Go Daddy Class 2 CA =================== -----BEGIN CERTIFICATE----- MIIEADCCAuigAwIBAgIBADANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEhMB8GA1UEChMY VGhlIEdvIERhZGR5IEdyb3VwLCBJbmMuMTEwLwYDVQQLEyhHbyBEYWRkeSBDbGFzcyAyIENlcnRp ZmljYXRpb24gQXV0aG9yaXR5MB4XDTA0MDYyOTE3MDYyMFoXDTM0MDYyOTE3MDYyMFowYzELMAkG A1UEBhMCVVMxITAfBgNVBAoTGFRoZSBHbyBEYWRkeSBHcm91cCwgSW5jLjExMC8GA1UECxMoR28g RGFkZHkgQ2xhc3MgMiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASAwDQYJKoZIhvcNAQEBBQAD ggENADCCAQgCggEBAN6d1+pXGEmhW+vXX0iG6r7d/+TvZxz0ZWizV3GgXne77ZtJ6XCAPVYYYwhv 2vLM0D9/AlQiVBDYsoHUwHU9S3/Hd8M+eKsaA7Ugay9qK7HFiH7Eux6wwdhFJ2+qN1j3hybX2C32 qRe3H3I2TqYXP2WYktsqbl2i/ojgC95/5Y0V4evLOtXiEqITLdiOr18SPaAIBQi2XKVlOARFmR6j YGB0xUGlcmIbYsUfb18aQr4CUWWoriMYavx4A6lNf4DD+qta/KFApMoZFv6yyO9ecw3ud72a9nmY vLEHZ6IVDd2gWMZEewo+YihfukEHU1jPEX44dMX4/7VpkI+EdOqXG68CAQOjgcAwgb0wHQYDVR0O BBYEFNLEsNKR1EwRcbNhyz2h/t2oatTjMIGNBgNVHSMEgYUwgYKAFNLEsNKR1EwRcbNhyz2h/t2o atTjoWekZTBjMQswCQYDVQQGEwJVUzEhMB8GA1UEChMYVGhlIEdvIERhZGR5IEdyb3VwLCBJbmMu MTEwLwYDVQQLEyhHbyBEYWRkeSBDbGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggEAMAwG A1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBADJL87LKPpH8EsahB4yOd6AzBhRckB4Y9wim PQoZ+YeAEW5p5JYXMP80kWNyOO7MHAGjHZQopDH2esRU1/blMVgDoszOYtuURXO1v0XJJLXVggKt I3lpjbi2Tc7PTMozI+gciKqdi0FuFskg5YmezTvacPd+mSYgFFQlq25zheabIZ0KbIIOqPjCDPoQ HmyW74cNxA9hi63ugyuV+I6ShHI56yDqg+2DzZduCLzrTia2cyvk0/ZM/iZx4mERdEr/VxqHD3VI Ls9RaRegAhJhldXRQLIQTO7ErBBDpqWeCtWVYpoNz4iCxTIM5CufReYNnyicsbkqWletNw+vHX/b vZ8= -----END CERTIFICATE----- Starfield Class 2 CA ==================== -----BEGIN CERTIFICATE----- MIIEDzCCAvegAwIBAgIBADANBgkqhkiG9w0BAQUFADBoMQswCQYDVQQGEwJVUzElMCMGA1UEChMc U3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMpU3RhcmZpZWxkIENsYXNzIDIg Q2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQwNjI5MTczOTE2WhcNMzQwNjI5MTczOTE2WjBo MQswCQYDVQQGEwJVUzElMCMGA1UEChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAG A1UECxMpU3RhcmZpZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEgMA0GCSqG SIb3DQEBAQUAA4IBDQAwggEIAoIBAQC3Msj+6XGmBIWtDBFk385N78gDGIc/oav7PKaf8MOh2tTY bitTkPskpD6E8J7oX+zlJ0T1KKY/e97gKvDIr1MvnsoFAZMej2YcOadN+lq2cwQlZut3f+dZxkqZ JRRU6ybH838Z1TBwj6+wRir/resp7defqgSHo9T5iaU0X9tDkYI22WY8sbi5gv2cOj4QyDvvBmVm epsZGD3/cVE8MC5fvj13c7JdBmzDI1aaK4UmkhynArPkPw2vCHmCuDY96pzTNbO8acr1zJ3o/WSN F4Azbl5KXZnJHoe0nRrA1W4TNSNe35tfPe/W93bC6j67eA0cQmdrBNj41tpvi/JEoAGrAgEDo4HF MIHCMB0GA1UdDgQWBBS/X7fRzt0fhvRbVazc1xDCDqmI5zCBkgYDVR0jBIGKMIGHgBS/X7fRzt0f hvRbVazc1xDCDqmI56FspGowaDELMAkGA1UEBhMCVVMxJTAjBgNVBAoTHFN0YXJmaWVsZCBUZWNo bm9sb2dpZXMsIEluYy4xMjAwBgNVBAsTKVN0YXJmaWVsZCBDbGFzcyAyIENlcnRpZmljYXRpb24g QXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAAWdP4id0ckaVaGs afPzWdqbAYcaT1epoXkJKtv3L7IezMdeatiDh6GX70k1PncGQVhiv45YuApnP+yz3SFmH8lU+nLM PUxA2IGvd56Deruix/U0F47ZEUD0/CwqTRV/p2JdLiXTAAsgGh1o+Re49L2L7ShZ3U0WixeDyLJl xy16paq8U4Zt3VekyvggQQto8PT7dL5WXXp59fkdheMtlb71cZBDzI0fmgAKhynpVSJYACPq4xJD KVtHCN2MQWplBqjlIapBtJUhlbl90TSrE9atvNziPTnNvT51cKEYWQPJIrSPnNVeKtelttQKbfi3 QBFGmh95DmK/D5fs4C8fF5Q= -----END CERTIFICATE----- StartCom Certification Authority ================================ -----BEGIN CERTIFICATE----- MIIHyTCCBbGgAwIBAgIBATANBgkqhkiG9w0BAQUFADB9MQswCQYDVQQGEwJJTDEWMBQGA1UEChMN U3RhcnRDb20gTHRkLjErMCkGA1UECxMiU2VjdXJlIERpZ2l0YWwgQ2VydGlmaWNhdGUgU2lnbmlu ZzEpMCcGA1UEAxMgU3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDYwOTE3MTk0 NjM2WhcNMzYwOTE3MTk0NjM2WjB9MQswCQYDVQQGEwJJTDEWMBQGA1UEChMNU3RhcnRDb20gTHRk LjErMCkGA1UECxMiU2VjdXJlIERpZ2l0YWwgQ2VydGlmaWNhdGUgU2lnbmluZzEpMCcGA1UEAxMg U3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAw ggIKAoICAQDBiNsJvGxGfHiflXu1M5DycmLWwTYgIiRezul38kMKogZkpMyONvg45iPwbm2xPN1y o4UcodM9tDMr0y+v/uqwQVlntsQGfQqedIXWeUyAN3rfOQVSWff0G0ZDpNKFhdLDcfN1YjS6LIp/ Ho/u7TTQEceWzVI9ujPW3U3eCztKS5/CJi/6tRYccjV3yjxd5srhJosaNnZcAdt0FCX+7bWgiA/d eMotHweXMAEtcnn6RtYTKqi5pquDSR3l8u/d5AGOGAqPY1MWhWKpDhk6zLVmpsJrdAfkK+F2PrRt 2PZE4XNiHzvEvqBTViVsUQn3qqvKv3b9bZvzndu/PWa8DFaqr5hIlTpL36dYUNk4dalb6kMMAv+Z 6+hsTXBbKWWc3apdzK8BMewM69KN6Oqce+Zu9ydmDBpI125C4z/eIT574Q1w+2OqqGwaVLRcJXrJ osmLFqa7LH4XXgVNWG4SHQHuEhANxjJ/GP/89PrNbpHoNkm+Gkhpi8KWTRoSsmkXwQqQ1vp5Iki/ untp+HDH+no32NgN0nZPV/+Qt+OR0t3vwmC3Zzrd/qqc8NSLf3Iizsafl7b4r4qgEKjZ+xjGtrVc UjyJthkqcwEKDwOzEmDyei+B26Nu/yYwl/WL3YlXtq09s68rxbd2AvCl1iuahhQqcvbjM4xdCUsT 37uMdBNSSwIDAQABo4ICUjCCAk4wDAYDVR0TBAUwAwEB/zALBgNVHQ8EBAMCAa4wHQYDVR0OBBYE FE4L7xqkQFulF2mHMMo0aEPQQa7yMGQGA1UdHwRdMFswLKAqoCiGJmh0dHA6Ly9jZXJ0LnN0YXJ0 Y29tLm9yZy9zZnNjYS1jcmwuY3JsMCugKaAnhiVodHRwOi8vY3JsLnN0YXJ0Y29tLm9yZy9zZnNj YS1jcmwuY3JsMIIBXQYDVR0gBIIBVDCCAVAwggFMBgsrBgEEAYG1NwEBATCCATswLwYIKwYBBQUH AgEWI2h0dHA6Ly9jZXJ0LnN0YXJ0Y29tLm9yZy9wb2xpY3kucGRmMDUGCCsGAQUFBwIBFilodHRw Oi8vY2VydC5zdGFydGNvbS5vcmcvaW50ZXJtZWRpYXRlLnBkZjCB0AYIKwYBBQUHAgIwgcMwJxYg U3RhcnQgQ29tbWVyY2lhbCAoU3RhcnRDb20pIEx0ZC4wAwIBARqBl0xpbWl0ZWQgTGlhYmlsaXR5 LCByZWFkIHRoZSBzZWN0aW9uICpMZWdhbCBMaW1pdGF0aW9ucyogb2YgdGhlIFN0YXJ0Q29tIENl cnRpZmljYXRpb24gQXV0aG9yaXR5IFBvbGljeSBhdmFpbGFibGUgYXQgaHR0cDovL2NlcnQuc3Rh cnRjb20ub3JnL3BvbGljeS5wZGYwEQYJYIZIAYb4QgEBBAQDAgAHMDgGCWCGSAGG+EIBDQQrFilT dGFydENvbSBGcmVlIFNTTCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTANBgkqhkiG9w0BAQUFAAOC AgEAFmyZ9GYMNPXQhV59CuzaEE44HF7fpiUFS5Eyweg78T3dRAlbB0mKKctmArexmvclmAk8jhvh 3TaHK0u7aNM5Zj2gJsfyOZEdUauCe37Vzlrk4gNXcGmXCPleWKYK34wGmkUWFjgKXlf2Ysd6AgXm vB618p70qSmD+LIU424oh0TDkBreOKk8rENNZEXO3SipXPJzewT4F+irsfMuXGRuczE6Eri8sxHk fY+BUZo7jYn0TZNmezwD7dOaHZrzZVD1oNB1ny+v8OqCQ5j4aZyJecRDjkZy42Q2Eq/3JR44iZB3 fsNrarnDy0RLrHiQi+fHLB5LEUTINFInzQpdn4XBidUaePKVEFMy3YCEZnXZtWgo+2EuvoSoOMCZ EoalHmdkrQYuL6lwhceWD3yJZfWOQ1QOq92lgDmUYMA0yZZwLKMS9R9Ie70cfmu3nZD0Ijuu+Pwq yvqCUqDvr0tVk+vBtfAii6w0TiYiBKGHLHVKt+V9E9e4DGTANtLJL4YSjCMJwRuCO3NJo2pXh5Tl 1njFmUNj403gdy3hZZlyaQQaRwnmDwFWJPsfvw55qVguucQJAX6Vum0ABj6y6koQOdjQK/W/7HW/ lwLFCRsI3FU34oH7N4RDYiDK51ZLZer+bMEkkyShNOsF/5oirpt9P/FlUQqmMGqz9IgcgA38coro g14= -----END CERTIFICATE----- Taiwan GRCA =========== -----BEGIN CERTIFICATE----- MIIFcjCCA1qgAwIBAgIQH51ZWtcvwgZEpYAIaeNe9jANBgkqhkiG9w0BAQUFADA/MQswCQYDVQQG EwJUVzEwMC4GA1UECgwnR292ZXJubWVudCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4X DTAyMTIwNTEzMjMzM1oXDTMyMTIwNTEzMjMzM1owPzELMAkGA1UEBhMCVFcxMDAuBgNVBAoMJ0dv dmVybm1lbnQgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCAiIwDQYJKoZIhvcNAQEBBQAD ggIPADCCAgoCggIBAJoluOzMonWoe/fOW1mKydGGEghU7Jzy50b2iPN86aXfTEc2pBsBHH8eV4qN w8XRIePaJD9IK/ufLqGU5ywck9G/GwGHU5nOp/UKIXZ3/6m3xnOUT0b3EEk3+qhZSV1qgQdW8or5 BtD3cCJNtLdBuTK4sfCxw5w/cP1T3YGq2GN49thTbqGsaoQkclSGxtKyyhwOeYHWtXBiCAEuTk8O 1RGvqa/lmr/czIdtJuTJV6L7lvnM4T9TjGxMfptTCAtsF/tnyMKtsc2AtJfcdgEWFelq16TheEfO htX7MfP6Mb40qij7cEwdScevLJ1tZqa2jWR+tSBqnTuBto9AAGdLiYa4zGX+FVPpBMHWXx1E1wov J5pGfaENda1UhhXcSTvxls4Pm6Dso3pdvtUqdULle96ltqqvKKyskKw4t9VoNSZ63Pc78/1Fm9G7 Q3hub/FCVGqY8A2tl+lSXunVanLeavcbYBT0peS2cWeqH+riTcFCQP5nRhc4L0c/cZyu5SHKYS1t B6iEfC3uUSXxY5Ce/eFXiGvviiNtsea9P63RPZYLhY3Naye7twWb7LuRqQoHEgKXTiCQ8P8NHuJB O9NAOueNXdpm5AKwB1KYXA6OM5zCppX7VRluTI6uSw+9wThNXo+EHWbNxWCWtFJaBYmOlXqYwZE8 lSOyDvR5tMl8wUohAgMBAAGjajBoMB0GA1UdDgQWBBTMzO/MKWCkO7GStjz6MmKPrCUVOzAMBgNV HRMEBTADAQH/MDkGBGcqBwAEMTAvMC0CAQAwCQYFKw4DAhoFADAHBgVnKgMAAAQUA5vwIhP/lSg2 09yewDL7MTqKUWUwDQYJKoZIhvcNAQEFBQADggIBAECASvomyc5eMN1PhnR2WPWus4MzeKR6dBcZ TulStbngCnRiqmjKeKBMmo4sIy7VahIkv9Ro04rQ2JyftB8M3jh+Vzj8jeJPXgyfqzvS/3WXy6Tj Zwj/5cAWtUgBfen5Cv8b5Wppv3ghqMKnI6mGq3ZW6A4M9hPdKmaKZEk9GhiHkASfQlK3T8v+R0F2 Ne//AHY2RTKbxkaFXeIksB7jSJaYV0eUVXoPQbFEJPPB/hprv4j9wabak2BegUqZIJxIZhm1AHlU D7gsL0u8qV1bYH+Mh6XgUmMqvtg7hUAV/h62ZT/FS9p+tXo1KaMuephgIqP0fSdOLeq0dDzpD6Qz DxARvBMB1uUO07+1EqLhRSPAzAhuYbeJq4PjJB7mXQfnHyA+z2fI56wwbSdLaG5LKlwCCDTb+Hbk Z6MmnD+iMsJKxYEYMRBWqoTvLQr/uB930r+lWKBi5NdLkXWNiYCYfm3LU05er/ayl4WXudpVBrkk 7tfGOB5jGxI7leFYrPLfhNVfmS8NVVvmONsuP3LpSIXLuykTjx44VbnzssQwmSNOXfJIoRIM3BKQ CZBUkQM8R+XVyWXgt0t97EfTsws+rZ7QdAAO671RrcDeLMDDav7v3Aun+kbfYNucpllQdSNpc5Oy +fwC00fmcc4QAu4njIT/rEUNE1yDMuAlpYYsfPQS -----END CERTIFICATE----- Firmaprofesional Root CA ======================== -----BEGIN CERTIFICATE----- MIIEVzCCAz+gAwIBAgIBATANBgkqhkiG9w0BAQUFADCBnTELMAkGA1UEBhMCRVMxIjAgBgNVBAcT GUMvIE11bnRhbmVyIDI0NCBCYXJjZWxvbmExQjBABgNVBAMTOUF1dG9yaWRhZCBkZSBDZXJ0aWZp Y2FjaW9uIEZpcm1hcHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2ODEmMCQGCSqGSIb3DQEJARYXY2FA ZmlybWFwcm9mZXNpb25hbC5jb20wHhcNMDExMDI0MjIwMDAwWhcNMTMxMDI0MjIwMDAwWjCBnTEL MAkGA1UEBhMCRVMxIjAgBgNVBAcTGUMvIE11bnRhbmVyIDI0NCBCYXJjZWxvbmExQjBABgNVBAMT OUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1hcHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2 ODEmMCQGCSqGSIb3DQEJARYXY2FAZmlybWFwcm9mZXNpb25hbC5jb20wggEiMA0GCSqGSIb3DQEB AQUAA4IBDwAwggEKAoIBAQDnIwNvbyOlXnjOlSztlB5uCp4Bx+ow0Syd3Tfom5h5VtP8c9/Qit5V j1H5WuretXDE7aTt/6MNbg9kUDGvASdYrv5sp0ovFy3Tc9UTHI9ZpTQsHVQERc1ouKDAA6XPhUJH lShbz++AbOCQl4oBPB3zhxAwJkh91/zpnZFx/0GaqUC1N5wpIE8fUuOgfRNtVLcK3ulqTgesrBlf 3H5idPayBQC6haD9HThuy1q7hryUZzM1gywfI834yJFxzJeL764P3CkDG8A563DtwW4O2GcLiam8 NeTvtjS0pbbELaW+0MOUJEjb35bTALVmGotmBQ/dPz/LP6pemkr4tErvlTcbAgMBAAGjgZ8wgZww KgYDVR0RBCMwIYYfaHR0cDovL3d3dy5maXJtYXByb2Zlc2lvbmFsLmNvbTASBgNVHRMBAf8ECDAG AQH/AgEBMCsGA1UdEAQkMCKADzIwMDExMDI0MjIwMDAwWoEPMjAxMzEwMjQyMjAwMDBaMA4GA1Ud DwEB/wQEAwIBBjAdBgNVHQ4EFgQUMwugZtHq2s7eYpMEKFK1FH84aLcwDQYJKoZIhvcNAQEFBQAD ggEBAEdz/o0nVPD11HecJ3lXV7cVVuzH2Fi3AQL0M+2TUIiefEaxvT8Ub/GzR0iLjJcG1+p+o1wq u00vR+L4OQbJnC4xGgN49Lw4xiKLMzHwFgQEffl25EvXwOaD7FnMP97/T2u3Z36mhoEyIwOdyPdf wUpgpZKpsaSgYMN4h7Mi8yrrW6ntBas3D7Hi05V2Y1Z0jFhyGzflZKG+TQyTmAyX9odtsz/ny4Cm 7YjHX1BiAuiZdBbQ5rQ58SfLyEDW44YQqSMSkuBpQWOnryULwMWSyx6Yo1q6xTMPoJcB3X/ge9YG VM+h4k0460tQtcsm9MracEpqoeJ5quGnM/b9Sh/22WA= -----END CERTIFICATE----- Wells Fargo Root CA =================== -----BEGIN CERTIFICATE----- MIID5TCCAs2gAwIBAgIEOeSXnjANBgkqhkiG9w0BAQUFADCBgjELMAkGA1UEBhMCVVMxFDASBgNV BAoTC1dlbGxzIEZhcmdvMSwwKgYDVQQLEyNXZWxscyBGYXJnbyBDZXJ0aWZpY2F0aW9uIEF1dGhv cml0eTEvMC0GA1UEAxMmV2VsbHMgRmFyZ28gUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwHhcN MDAxMDExMTY0MTI4WhcNMjEwMTE0MTY0MTI4WjCBgjELMAkGA1UEBhMCVVMxFDASBgNVBAoTC1dl bGxzIEZhcmdvMSwwKgYDVQQLEyNXZWxscyBGYXJnbyBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTEv MC0GA1UEAxMmV2VsbHMgRmFyZ28gUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEiMA0GCSqG SIb3DQEBAQUAA4IBDwAwggEKAoIBAQDVqDM7Jvk0/82bfuUER84A4n135zHCLielTWi5MbqNQ1mX x3Oqfz1cQJ4F5aHiidlMuD+b+Qy0yGIZLEWukR5zcUHESxP9cMIlrCL1dQu3U+SlK93OvRw6esP3 E48mVJwWa2uv+9iWsWCaSOAlIiR5NM4OJgALTqv9i86C1y8IcGjBqAr5dE8Hq6T54oN+J3N0Prj5 OEL8pahbSCOz6+MlsoCultQKnMJ4msZoGK43YjdeUXWoWGPAUe5AeH6orxqg4bB4nVCMe+ez/I4j sNtlAHCEAQgAFG5Uhpq6zPk3EPbg3oQtnaSFN9OH4xXQwReQfhkhahKpdv0SAulPIV4XAgMBAAGj YTBfMA8GA1UdEwEB/wQFMAMBAf8wTAYDVR0gBEUwQzBBBgtghkgBhvt7hwcBCzAyMDAGCCsGAQUF BwIBFiRodHRwOi8vd3d3LndlbGxzZmFyZ28uY29tL2NlcnRwb2xpY3kwDQYJKoZIhvcNAQEFBQAD ggEBANIn3ZwKdyu7IvICtUpKkfnRLb7kuxpo7w6kAOnu5+/u9vnldKTC2FJYxHT7zmu1Oyl5GFrv m+0fazbuSCUlFLZWohDo7qd/0D+j0MNdJu4HzMPBJCGHHt8qElNvQRbn7a6U+oxy+hNH8Dx+rn0R OhPs7fpvcmR7nX1/Jv16+yWt6j4pf0zjAFcysLPp7VMX2YuyFA4w6OXVE8Zkr8QA1dhYJPz1j+zx x32l2w8n0cbyQIjmH/ZhqPRCyLk306m+LFZ4wnKbWV01QIroTmMatukgalHizqSQ33ZwmVxwQ023 tqcZZE6St8WRPH9IFmV7Fv3L/PvZ1dZPIWU7Sn9Ho/s= -----END CERTIFICATE----- Swisscom Root CA 1 ================== -----BEGIN CERTIFICATE----- MIIF2TCCA8GgAwIBAgIQXAuFXAvnWUHfV8w/f52oNjANBgkqhkiG9w0BAQUFADBkMQswCQYDVQQG EwJjaDERMA8GA1UEChMIU3dpc3Njb20xJTAjBgNVBAsTHERpZ2l0YWwgQ2VydGlmaWNhdGUgU2Vy dmljZXMxGzAZBgNVBAMTElN3aXNzY29tIFJvb3QgQ0EgMTAeFw0wNTA4MTgxMjA2MjBaFw0yNTA4 MTgyMjA2MjBaMGQxCzAJBgNVBAYTAmNoMREwDwYDVQQKEwhTd2lzc2NvbTElMCMGA1UECxMcRGln aXRhbCBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczEbMBkGA1UEAxMSU3dpc3Njb20gUm9vdCBDQSAxMIIC IjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA0LmwqAzZuz8h+BvVM5OAFmUgdbI9m2BtRsiM MW8Xw/qabFbtPMWRV8PNq5ZJkCoZSx6jbVfd8StiKHVFXqrWW/oLJdihFvkcxC7mlSpnzNApbjyF NDhhSbEAn9Y6cV9Nbc5fuankiX9qUvrKm/LcqfmdmUc/TilftKaNXXsLmREDA/7n29uj/x2lzZAe AR81sH8A25Bvxn570e56eqeqDFdvpG3FEzuwpdntMhy0XmeLVNxzh+XTF3xmUHJd1BpYwdnP2IkC b6dJtDZd0KTeByy2dbcokdaXvij1mB7qWybJvbCXc9qukSbraMH5ORXWZ0sKbU/Lz7DkQnGMU3nn 7uHbHaBuHYwadzVcFh4rUx80i9Fs/PJnB3r1re3WmquhsUvhzDdf/X/NTa64H5xD+SpYVUNFvJbN cA78yeNmuk6NO4HLFWR7uZToXTNShXEuT46iBhFRyePLoW4xCGQMwtI89Tbo19AOeCMgkckkKmUp WyL3Ic6DXqTz3kvTaI9GdVyDCW4pa8RwjPWd1yAv/0bSKzjCL3UcPX7ape8eYIVpQtPM+GP+HkM5 haa2Y0EQs3MevNP6yn0WR+Kn1dCjigoIlmJWbjTb2QK5MHXjBNLnj8KwEUAKrNVxAmKLMb7dxiNY MUJDLXT5xp6mig/p/r+D5kNXJLrvRjSq1xIBOO0CAwEAAaOBhjCBgzAOBgNVHQ8BAf8EBAMCAYYw HQYDVR0hBBYwFDASBgdghXQBUwABBgdghXQBUwABMBIGA1UdEwEB/wQIMAYBAf8CAQcwHwYDVR0j BBgwFoAUAyUv3m+CATpcLNwroWm1Z9SM0/0wHQYDVR0OBBYEFAMlL95vggE6XCzcK6FptWfUjNP9 MA0GCSqGSIb3DQEBBQUAA4ICAQA1EMvspgQNDQ/NwNurqPKIlwzfky9NfEBWMXrrpA9gzXrzvsMn jgM+pN0S734edAY8PzHyHHuRMSG08NBsl9Tpl7IkVh5WwzW9iAUPWxAaZOHHgjD5Mq2eUCzneAXQ MbFamIp1TpBcahQq4FJHgmDmHtqBsfsUC1rxn9KVuj7QG9YVHaO+htXbD8BJZLsuUBlL0iT43R4H VtA4oJVwIHaM190e3p9xxCPvgxNcoyQVTSlAPGrEqdi3pkSlDfTgnXceQHAm/NrZNuR55LU/vJtl vrsRls/bxig5OgjOR1tTWsWZ/l2p3e9M1MalrQLmjAcSHm8D0W+go/MpvRLHUKKwf4ipmXeascCl OS5cfGniLLDqN2qk4Vrh9VDlg++luyqI54zb/W1elxmofmZ1a3Hqv7HHb6D0jqTsNFFbjCYDcKF3 1QESVwA12yPeDooomf2xEG9L/zgtYE4snOtnta1J7ksfrK/7DZBaZmBwXarNeNQk7shBoJMBkpxq nvy5JMWzFYJ+vq6VK+uxwNrjAWALXmmshFZhvnEX/h0TD/7Gh0Xp/jKgGg0TpJRVcaUWi7rKibCy x/yP2FS1k2Kdzs9Z+z0YzirLNRWCXf9UIltxUvu3yf5gmwBBZPCqKuy2QkPOiWaByIufOVQDJdMW NY6E0F/6MBr1mmz0DlP5OlvRHA== -----END CERTIFICATE----- DigiCert Assured ID Root CA =========================== -----BEGIN CERTIFICATE----- MIIDtzCCAp+gAwIBAgIQDOfg5RfYRv6P5WD8G/AwOTANBgkqhkiG9w0BAQUFADBlMQswCQYDVQQG EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSQw IgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0EwHhcNMDYxMTEwMDAwMDAwWhcNMzEx MTEwMDAwMDAwWjBlMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQL ExB3d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0Ew ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCtDhXO5EOAXLGH87dg+XESpa7cJpSIqvTO 9SA5KFhgDPiA2qkVlTJhPLWxKISKityfCgyDF3qPkKyK53lTXDGEKvYPmDI2dsze3Tyoou9q+yHy UmHfnyDXH+Kx2f4YZNISW1/5WBg1vEfNoTb5a3/UsDg+wRvDjDPZ2C8Y/igPs6eD1sNuRMBhNZYW /lmci3Zt1/GiSw0r/wty2p5g0I6QNcZ4VYcgoc/lbQrISXwxmDNsIumH0DJaoroTghHtORedmTpy oeb6pNnVFzF1roV9Iq4/AUaG9ih5yLHa5FcXxH4cDrC0kqZWs72yl+2qp/C3xag/lRbQ/6GW6whf GHdPAgMBAAGjYzBhMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRF 66Kv9JLLgjEtUYunpyGd823IDzAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYunpyGd823IDzANBgkq hkiG9w0BAQUFAAOCAQEAog683+Lt8ONyc3pklL/3cmbYMuRCdWKuh+vy1dneVrOfzM4UKLkNl2Bc EkxY5NM9g0lFWJc1aRqoR+pWxnmrEthngYTffwk8lOa4JiwgvT2zKIn3X/8i4peEH+ll74fg38Fn SbNd67IJKusm7Xi+fT8r87cmNW1fiQG2SVufAQWbqz0lwcy2f8Lxb4bG+mRo64EtlOtCt/qMHt1i 8b5QZ7dsvfPxH2sMNgcWfzd8qVttevESRmCD1ycEvkvOl77DZypoEd+A5wwzZr8TDRRu838fYxAe +o0bJW1sj6W3YQGx0qMmoRBxna3iw/nDmVG3KwcIzi7mULKn+gpFL6Lw8g== -----END CERTIFICATE----- DigiCert Global Root CA ======================= -----BEGIN CERTIFICATE----- MIIDrzCCApegAwIBAgIQCDvgVpBCRrGhdWrJWZHHSjANBgkqhkiG9w0BAQUFADBhMQswCQYDVQQG EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSAw HgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBDQTAeFw0wNjExMTAwMDAwMDBaFw0zMTExMTAw MDAwMDBaMGExCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3 dy5kaWdpY2VydC5jb20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IENBMIIBIjANBgkq hkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4jvhEXLeqKTTo1eqUKKPC3eQyaKl7hLOllsBCSDMAZOn TjC3U/dDxGkAV53ijSLdhwZAAIEJzs4bg7/fzTtxRuLWZscFs3YnFo97nh6Vfe63SKMI2tavegw5 BmV/Sl0fvBf4q77uKNd0f3p4mVmFaG5cIzJLv07A6Fpt43C/dxC//AH2hdmoRBBYMql1GNXRor5H 4idq9Joz+EkIYIvUX7Q6hL+hqkpMfT7PT19sdl6gSzeRntwi5m3OFBqOasv+zbMUZBfHWymeMr/y 7vrTC0LUq7dBMtoM1O/4gdW7jVg/tRvoSSiicNoxBN33shbyTApOB6jtSj1etX+jkMOvJwIDAQAB o2MwYTAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUA95QNVbRTLtm 8KPiGxvDl7I90VUwHwYDVR0jBBgwFoAUA95QNVbRTLtm8KPiGxvDl7I90VUwDQYJKoZIhvcNAQEF BQADggEBAMucN6pIExIK+t1EnE9SsPTfrgT1eXkIoyQY/EsrhMAtudXH/vTBH1jLuG2cenTnmCmr EbXjcKChzUyImZOMkXDiqw8cvpOp/2PV5Adg06O/nVsJ8dWO41P0jmP6P6fbtGbfYmbW0W5BjfIt tep3Sp+dWOIrWcBAI+0tKIJFPnlUkiaY4IBIqDfv8NZ5YBberOgOzW6sRBc4L0na4UU+Krk2U886 UAb3LujEV0lsYSEY1QSteDwsOoBrp+uvFRTp2InBuThs4pFsiv9kuXclVzDAGySj4dzp30d8tbQk CAUw7C29C79Fv1C5qfPrmAESrciIxpg0X40KPMbp1ZWVbd4= -----END CERTIFICATE----- DigiCert High Assurance EV Root CA ================================== -----BEGIN CERTIFICATE----- MIIDxTCCAq2gAwIBAgIQAqxcJmoLQJuPC3nyrkYldzANBgkqhkiG9w0BAQUFADBsMQswCQYDVQQG EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSsw KQYDVQQDEyJEaWdpQ2VydCBIaWdoIEFzc3VyYW5jZSBFViBSb290IENBMB4XDTA2MTExMDAwMDAw MFoXDTMxMTExMDAwMDAwMFowbDELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZ MBcGA1UECxMQd3d3LmRpZ2ljZXJ0LmNvbTErMCkGA1UEAxMiRGlnaUNlcnQgSGlnaCBBc3N1cmFu Y2UgRVYgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMbM5XPm+9S75S0t Mqbf5YE/yc0lSbZxKsPVlDRnogocsF9ppkCxxLeyj9CYpKlBWTrT3JTWPNt0OKRKzE0lgvdKpVMS OO7zSW1xkX5jtqumX8OkhPhPYlG++MXs2ziS4wblCJEMxChBVfvLWokVfnHoNb9Ncgk9vjo4UFt3 MRuNs8ckRZqnrG0AFFoEt7oT61EKmEFBIk5lYYeBQVCmeVyJ3hlKV9Uu5l0cUyx+mM0aBhakaHPQ NAQTXKFx01p8VdteZOE3hzBWBOURtCmAEvF5OYiiAhF8J2a3iLd48soKqDirCmTCv2ZdlYTBoSUe h10aUAsgEsxBu24LUTi4S8sCAwEAAaNjMGEwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMB Af8wHQYDVR0OBBYEFLE+w2kD+L9HAdSYJhoIAu9jZCvDMB8GA1UdIwQYMBaAFLE+w2kD+L9HAdSY JhoIAu9jZCvDMA0GCSqGSIb3DQEBBQUAA4IBAQAcGgaX3NecnzyIZgYIVyHbIUf4KmeqvxgydkAQ V8GK83rZEWWONfqe/EW1ntlMMUu4kehDLI6zeM7b41N5cdblIZQB2lWHmiRk9opmzN6cN82oNLFp myPInngiK3BD41VHMWEZ71jFhS9OMPagMRYjyOfiZRYzy78aG6A9+MpeizGLYAiJLQwGXFK3xPkK mNEVX58Svnw2Yzi9RKR/5CYrCsSXaQ3pjOLAEFe4yHYSkVXySGnYvCoCWw9E1CAx2/S6cCZdkGCe vEsXCS+0yx5DaMkHJ8HSXPfqIbloEpw8nL+e/IBcm2PN7EeqJSdnoDfzAIJ9VNep+OkuE6N36B9K -----END CERTIFICATE----- Certplus Class 2 Primary CA =========================== -----BEGIN CERTIFICATE----- MIIDkjCCAnqgAwIBAgIRAIW9S/PY2uNp9pTXX8OlRCMwDQYJKoZIhvcNAQEFBQAwPTELMAkGA1UE BhMCRlIxETAPBgNVBAoTCENlcnRwbHVzMRswGQYDVQQDExJDbGFzcyAyIFByaW1hcnkgQ0EwHhcN OTkwNzA3MTcwNTAwWhcNMTkwNzA2MjM1OTU5WjA9MQswCQYDVQQGEwJGUjERMA8GA1UEChMIQ2Vy dHBsdXMxGzAZBgNVBAMTEkNsYXNzIDIgUHJpbWFyeSBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEP ADCCAQoCggEBANxQltAS+DXSCHh6tlJw/W/uz7kRy1134ezpfgSN1sxvc0NXYKwzCkTsA18cgCSR 5aiRVhKC9+Ar9NuuYS6JEI1rbLqzAr3VNsVINyPi8Fo3UjMXEuLRYE2+L0ER4/YXJQyLkcAbmXuZ Vg2v7tK8R1fjeUl7NIknJITesezpWE7+Tt9avkGtrAjFGA7v0lPubNCdEgETjdyAYveVqUSISnFO YFWe2yMZeVYHDD9jC1yw4r5+FfyUM1hBOHTE4Y+L3yasH7WLO7dDWWuwJKZtkIvEcupdM5i3y95e e++U8Rs+yskhwcWYAqqi9lt3m/V+llU0HGdpwPFC40es/CgcZlUCAwEAAaOBjDCBiTAPBgNVHRME CDAGAQH/AgEKMAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQU43Mt38sOKAze3bOkynm4jrvoMIkwEQYJ YIZIAYb4QgEBBAQDAgEGMDcGA1UdHwQwMC4wLKAqoCiGJmh0dHA6Ly93d3cuY2VydHBsdXMuY29t L0NSTC9jbGFzczIuY3JsMA0GCSqGSIb3DQEBBQUAA4IBAQCnVM+IRBnL39R/AN9WM2K191EBkOvD P9GIROkkXe/nFL0gt5o8AP5tn9uQ3Nf0YtaLcF3n5QRIqWh8yfFC82x/xXp8HVGIutIKPidd3i1R TtMTZGnkLuPT55sJmabglZvOGtd/vjzOUrMRFcEPF80Du5wlFbqidon8BvEY0JNLDnyCt6X09l/+ 7UCmnYR0ObncHoUW2ikbhiMAybuJfm6AiB4vFLQDJKgybwOaRywwvlbGp0ICcBvqQNi6BQNwB6SW //1IMwrh3KWBkJtN3X3n57LNXMhqlfil9o3EXXgIvnsG1knPGTZQIy4I5p4FTUcY1Rbpsda2ENW7 l7+ijrRU -----END CERTIFICATE----- DST Root CA X3 ============== -----BEGIN CERTIFICATE----- MIIDSjCCAjKgAwIBAgIQRK+wgNajJ7qJMDmGLvhAazANBgkqhkiG9w0BAQUFADA/MSQwIgYDVQQK ExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMTDkRTVCBSb290IENBIFgzMB4X DTAwMDkzMDIxMTIxOVoXDTIxMDkzMDE0MDExNVowPzEkMCIGA1UEChMbRGlnaXRhbCBTaWduYXR1 cmUgVHJ1c3QgQ28uMRcwFQYDVQQDEw5EU1QgUm9vdCBDQSBYMzCCASIwDQYJKoZIhvcNAQEBBQAD ggEPADCCAQoCggEBAN+v6ZdQCINXtMxiZfaQguzH0yxrMMpb7NnDfcdAwRgUi+DoM3ZJKuM/IUmT rE4Orz5Iy2Xu/NMhD2XSKtkyj4zl93ewEnu1lcCJo6m67XMuegwGMoOifooUMM0RoOEqOLl5CjH9 UL2AZd+3UWODyOKIYepLYYHsUmu5ouJLGiifSKOeDNoJjj4XLh7dIN9bxiqKqy69cK3FCxolkHRy xXtqqzTWMIn/5WgTe1QLyNau7Fqckh49ZLOMxt+/yUFw7BZy1SbsOFU5Q9D8/RhcQPGX69Wam40d utolucbY38EVAjqr2m7xPi71XAicPNaDaeQQmxkqtilX4+U9m5/wAl0CAwEAAaNCMEAwDwYDVR0T AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMSnsaR7LHH62+FLkHX/xBVghYkQ MA0GCSqGSIb3DQEBBQUAA4IBAQCjGiybFwBcqR7uKGY3Or+Dxz9LwwmglSBd49lZRNI+DT69ikug dB/OEIKcdBodfpga3csTS7MgROSR6cz8faXbauX+5v3gTt23ADq1cEmv8uXrAvHRAosZy5Q6XkjE GB5YGV8eAlrwDPGxrancWYaLbumR9YbK+rlmM6pZW87ipxZzR8srzJmwN0jP41ZL9c8PDHIyh8bw RLtTcm1D9SZImlJnt1ir/md2cXjbDaJWFBM5JDGFoqgCWjBH4d1QB7wCCZAA62RjYJsWvIjJEubS fZGL+T0yjWW06XyxV3bqxbYoOb8VZRzI9neWagqNdwvYkQsEjgfbKbYK7p2CNTUQ -----END CERTIFICATE----- DST ACES CA X6 ============== -----BEGIN CERTIFICATE----- MIIECTCCAvGgAwIBAgIQDV6ZCtadt3js2AdWO4YV2TANBgkqhkiG9w0BAQUFADBbMQswCQYDVQQG EwJVUzEgMB4GA1UEChMXRGlnaXRhbCBTaWduYXR1cmUgVHJ1c3QxETAPBgNVBAsTCERTVCBBQ0VT MRcwFQYDVQQDEw5EU1QgQUNFUyBDQSBYNjAeFw0wMzExMjAyMTE5NThaFw0xNzExMjAyMTE5NTha MFsxCzAJBgNVBAYTAlVTMSAwHgYDVQQKExdEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdDERMA8GA1UE CxMIRFNUIEFDRVMxFzAVBgNVBAMTDkRTVCBBQ0VTIENBIFg2MIIBIjANBgkqhkiG9w0BAQEFAAOC AQ8AMIIBCgKCAQEAuT31LMmU3HWKlV1j6IR3dma5WZFcRt2SPp/5DgO0PWGSvSMmtWPuktKe1jzI DZBfZIGxqAgNTNj50wUoUrQBJcWVHAx+PhCEdc/BGZFjz+iokYi5Q1K7gLFViYsx+tC3dr5BPTCa pCIlF3PoHuLTrCq9Wzgh1SpL11V94zpVvddtawJXa+ZHfAjIgrrep4c9oW24MFbCswKBXy314pow GCi4ZtPLAZZv6opFVdbgnf9nKxcCpk4aahELfrd755jWjHZvwTvbUJN+5dCOHze4vbrGn2zpfDPy MjwmR/onJALJfh1biEITajV8fTXpLmaRcpPVMibEdPVTo7NdmvYJywIDAQABo4HIMIHFMA8GA1Ud EwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgHGMB8GA1UdEQQYMBaBFHBraS1vcHNAdHJ1c3Rkc3Qu Y29tMGIGA1UdIARbMFkwVwYKYIZIAWUDAgEBATBJMEcGCCsGAQUFBwIBFjtodHRwOi8vd3d3LnRy dXN0ZHN0LmNvbS9jZXJ0aWZpY2F0ZXMvcG9saWN5L0FDRVMtaW5kZXguaHRtbDAdBgNVHQ4EFgQU CXIGThhDD+XWzMNqizF7eI+og7gwDQYJKoZIhvcNAQEFBQADggEBAKPYjtay284F5zLNAdMEA+V2 5FYrnJmQ6AgwbN99Pe7lv7UkQIRJ4dEorsTCOlMwiPH1d25Ryvr/ma8kXxug/fKshMrfqfBfBC6t Fr8hlxCBPeP/h40y3JTlR4peahPJlJU90u7INJXQgNStMgiAVDzgvVJT11J8smk/f3rPanTK+gQq nExaBqXpIK1FZg9p8d2/6eMyi/rgwYZNcjwu2JN4Cir42NInPRmJX1p7ijvMDNpRrscL9yuwNwXs vFcj4jjSm2jzVhKIT0J8uDHEtdvkyCE06UgRNe76x5JXxZ805Mf29w4LTJxoeHtxMcfrHuBnQfO3 oKfN5XozNmr6mis= -----END CERTIFICATE----- TURKTRUST Certificate Services Provider Root 1 ============================================== -----BEGIN CERTIFICATE----- MIID+zCCAuOgAwIBAgIBATANBgkqhkiG9w0BAQUFADCBtzE/MD0GA1UEAww2VMOcUktUUlVTVCBF bGVrdHJvbmlrIFNlcnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxMQswCQYDVQQGDAJUUjEP MA0GA1UEBwwGQU5LQVJBMVYwVAYDVQQKDE0oYykgMjAwNSBUw5xSS1RSVVNUIEJpbGdpIMSwbGV0 acWfaW0gdmUgQmlsacWfaW0gR8O8dmVubGnEn2kgSGl6bWV0bGVyaSBBLsWeLjAeFw0wNTA1MTMx MDI3MTdaFw0xNTAzMjIxMDI3MTdaMIG3MT8wPQYDVQQDDDZUw5xSS1RSVVNUIEVsZWt0cm9uaWsg U2VydGlmaWthIEhpem1ldCBTYcSfbGF5xLFjxLFzxLExCzAJBgNVBAYMAlRSMQ8wDQYDVQQHDAZB TktBUkExVjBUBgNVBAoMTShjKSAyMDA1IFTDnFJLVFJVU1QgQmlsZ2kgxLBsZXRpxZ9pbSB2ZSBC aWxpxZ9pbSBHw7x2ZW5sacSfaSBIaXptZXRsZXJpIEEuxZ4uMIIBIjANBgkqhkiG9w0BAQEFAAOC AQ8AMIIBCgKCAQEAylIF1mMD2Bxf3dJ7XfIMYGFbazt0K3gNfUW9InTojAPBxhEqPZW8qZSwu5GX yGl8hMW0kWxsE2qkVa2kheiVfrMArwDCBRj1cJ02i67L5BuBf5OI+2pVu32Fks66WJ/bMsW9Xe8i Si9BB35JYbOG7E6mQW6EvAPs9TscyB/C7qju6hJKjRTP8wrgUDn5CDX4EVmt5yLqS8oUBt5CurKZ 8y1UiBAG6uEaPj1nH/vO+3yC6BFdSsG5FOpU2WabfIl9BJpiyelSPJ6c79L1JuTm5Rh8i27fbMx4 W09ysstcP4wFjdFMjK2Sx+F4f2VsSQZQLJ4ywtdKxnWKWU51b0dewQIDAQABoxAwDjAMBgNVHRME BTADAQH/MA0GCSqGSIb3DQEBBQUAA4IBAQAV9VX/N5aAWSGk/KEVTCD21F/aAyT8z5Aa9CEKmu46 sWrv7/hg0Uw2ZkUd82YCdAR7kjCo3gp2D++Vbr3JN+YaDayJSFvMgzbC9UZcWYJWtNX+I7TYVBxE q8Sn5RTOPEFhfEPmzcSBCYsk+1Ql1haolgxnB2+zUEfjHCQo3SqYpGH+2+oSN7wBGjSFvW5P55Fy B0SFHljKVETd96y5y4khctuPwGkplyqjrhgjlxxBKot8KsF8kOipKMDTkcatKIdAaLX/7KfS0zgY nNN9aV3wxqUeJBujR/xpB2jn5Jq07Q+hh4cCzofSSE7hvP/L8XKSRGQDJereW26fyfJOrN3H -----END CERTIFICATE----- TURKTRUST Certificate Services Provider Root 2 ============================================== -----BEGIN CERTIFICATE----- MIIEPDCCAySgAwIBAgIBATANBgkqhkiG9w0BAQUFADCBvjE/MD0GA1UEAww2VMOcUktUUlVTVCBF bGVrdHJvbmlrIFNlcnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxMQswCQYDVQQGEwJUUjEP MA0GA1UEBwwGQW5rYXJhMV0wWwYDVQQKDFRUw5xSS1RSVVNUIEJpbGdpIMSwbGV0acWfaW0gdmUg QmlsacWfaW0gR8O8dmVubGnEn2kgSGl6bWV0bGVyaSBBLsWeLiAoYykgS2FzxLFtIDIwMDUwHhcN MDUxMTA3MTAwNzU3WhcNMTUwOTE2MTAwNzU3WjCBvjE/MD0GA1UEAww2VMOcUktUUlVTVCBFbGVr dHJvbmlrIFNlcnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxMQswCQYDVQQGEwJUUjEPMA0G A1UEBwwGQW5rYXJhMV0wWwYDVQQKDFRUw5xSS1RSVVNUIEJpbGdpIMSwbGV0acWfaW0gdmUgQmls acWfaW0gR8O8dmVubGnEn2kgSGl6bWV0bGVyaSBBLsWeLiAoYykgS2FzxLFtIDIwMDUwggEiMA0G CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCpNn7DkUNMwxmYCMjHWHtPFoylzkkBH3MOrHUTpvqe LCDe2JAOCtFp0if7qnefJ1Il4std2NiDUBd9irWCPwSOtNXwSadktx4uXyCcUHVPr+G1QRT0mJKI x+XlZEdhR3n9wFHxwZnn3M5q+6+1ATDcRhzviuyV79z/rxAc653YsKpqhRgNF8k+v/Gb0AmJQv2g QrSdiVFVKc8bcLyEVK3BEx+Y9C52YItdP5qtygy/p1Zbj3e41Z55SZI/4PGXJHpsmxcPbe9TmJEr 5A++WXkHeLuXlfSfadRYhwqp48y2WBmfJiGxxFmNskF1wK1pzpwACPI2/z7woQ8arBT9pmAPAgMB AAGjQzBBMB0GA1UdDgQWBBTZN7NOBf3Zz58SFq62iS/rJTqIHDAPBgNVHQ8BAf8EBQMDBwYAMA8G A1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAHJglrfJ3NgpXiOFX7KzLXb7iNcX/ntt Rbj2hWyfIvwqECLsqrkw9qtY1jkQMZkpAL2JZkH7dN6RwRgLn7Vhy506vvWolKMiVW4XSf/SKfE4 Jl3vpao6+XF75tpYHdN0wgH6PmlYX63LaL4ULptswLbcoCb6dxriJNoaN+BnrdFzgw2lGh1uEpJ+ hGIAF728JRhX8tepb1mIvDS3LoV4nZbcFMMsilKbloxSZj2GFotHuFEJjOp9zYhys2AzsfAKRO8P 9Qk3iCQOLGsgOqL6EfJANZxEaGM7rDNvY7wsu/LSy3Z9fYjYHcgFHW68lKlmjHdxx/qR+i9Rnuk5 UrbnBEI= -----END CERTIFICATE----- SwissSign Gold CA - G2 ====================== -----BEGIN CERTIFICATE----- MIIFujCCA6KgAwIBAgIJALtAHEP1Xk+wMA0GCSqGSIb3DQEBBQUAMEUxCzAJBgNVBAYTAkNIMRUw EwYDVQQKEwxTd2lzc1NpZ24gQUcxHzAdBgNVBAMTFlN3aXNzU2lnbiBHb2xkIENBIC0gRzIwHhcN MDYxMDI1MDgzMDM1WhcNMzYxMDI1MDgzMDM1WjBFMQswCQYDVQQGEwJDSDEVMBMGA1UEChMMU3dp c3NTaWduIEFHMR8wHQYDVQQDExZTd2lzc1NpZ24gR29sZCBDQSAtIEcyMIICIjANBgkqhkiG9w0B AQEFAAOCAg8AMIICCgKCAgEAr+TufoskDhJuqVAtFkQ7kpJcyrhdhJJCEyq8ZVeCQD5XJM1QiyUq t2/876LQwB8CJEoTlo8jE+YoWACjR8cGp4QjK7u9lit/VcyLwVcfDmJlD909Vopz2q5+bbqBHH5C jCA12UNNhPqE21Is8w4ndwtrvxEvcnifLtg+5hg3Wipy+dpikJKVyh+c6bM8K8vzARO/Ws/BtQpg vd21mWRTuKCWs2/iJneRjOBiEAKfNA+k1ZIzUd6+jbqEemA8atufK+ze3gE/bk3lUIbLtK/tREDF ylqM2tIrfKjuvqblCqoOpd8FUrdVxyJdMmqXl2MT28nbeTZ7hTpKxVKJ+STnnXepgv9VHKVxaSvR AiTysybUa9oEVeXBCsdtMDeQKuSeFDNeFhdVxVu1yzSJkvGdJo+hB9TGsnhQ2wwMC3wLjEHXuend jIj3o02yMszYF9rNt85mndT9Xv+9lz4pded+p2JYryU0pUHHPbwNUMoDAw8IWh+Vc3hiv69yFGkO peUDDniOJihC8AcLYiAQZzlG+qkDzAQ4embvIIO1jEpWjpEA/I5cgt6IoMPiaG59je883WX0XaxR 7ySArqpWl2/5rX3aYT+YdzylkbYcjCbaZaIJbcHiVOO5ykxMgI93e2CaHt+28kgeDrpOVG2Y4OGi GqJ3UM/EY5LsRxmd6+ZrzsECAwEAAaOBrDCBqTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUw AwEB/zAdBgNVHQ4EFgQUWyV7lqRlUX64OfPAeGZe6Drn8O4wHwYDVR0jBBgwFoAUWyV7lqRlUX64 OfPAeGZe6Drn8O4wRgYDVR0gBD8wPTA7BglghXQBWQECAQEwLjAsBggrBgEFBQcCARYgaHR0cDov L3JlcG9zaXRvcnkuc3dpc3NzaWduLmNvbS8wDQYJKoZIhvcNAQEFBQADggIBACe645R88a7A3hfm 5djV9VSwg/S7zV4Fe0+fdWavPOhWfvxyeDgD2StiGwC5+OlgzczOUYrHUDFu4Up+GC9pWbY9ZIEr 44OE5iKHjn3g7gKZYbge9LgriBIWhMIxkziWMaa5O1M/wySTVltpkuzFwbs4AOPsF6m43Md8AYOf Mke6UiI0HTJ6CVanfCU2qT1L2sCCbwq7EsiHSycR+R4tx5M/nttfJmtS2S6K8RTGRI0Vqbe/vd6m Gu6uLftIdxf+u+yvGPUqUfA5hJeVbG4bwyvEdGB5JbAKJ9/fXtI5z0V9QkvfsywexcZdylU6oJxp mo/a77KwPJ+HbBIrZXAVUjEaJM9vMSNQH4xPjyPDdEFjHFWoFN0+4FFQz/EbMFYOkrCChdiDyyJk vC24JdVUorgG6q2SpCSgwYa1ShNqR88uC1aVVMvOmttqtKay20EIhid392qgQmwLOM7XdVAyksLf KzAiSNDVQTglXaTpXZ/GlHXQRf0wl0OPkKsKx4ZzYEppLd6leNcG2mqeSz53OiATIgHQv2ieY2Br NU0LbbqhPcCT4H8js1WtciVORvnSFu+wZMEBnunKoGqYDs/YYPIvSbjkQuE4NRb0yG5P94FW6Lqj viOvrv1vA+ACOzB2+httQc8Bsem4yWb02ybzOqR08kkkW8mw0FfB+j564ZfJ -----END CERTIFICATE----- SwissSign Silver CA - G2 ======================== -----BEGIN CERTIFICATE----- MIIFvTCCA6WgAwIBAgIITxvUL1S7L0swDQYJKoZIhvcNAQEFBQAwRzELMAkGA1UEBhMCQ0gxFTAT BgNVBAoTDFN3aXNzU2lnbiBBRzEhMB8GA1UEAxMYU3dpc3NTaWduIFNpbHZlciBDQSAtIEcyMB4X DTA2MTAyNTA4MzI0NloXDTM2MTAyNTA4MzI0NlowRzELMAkGA1UEBhMCQ0gxFTATBgNVBAoTDFN3 aXNzU2lnbiBBRzEhMB8GA1UEAxMYU3dpc3NTaWduIFNpbHZlciBDQSAtIEcyMIICIjANBgkqhkiG 9w0BAQEFAAOCAg8AMIICCgKCAgEAxPGHf9N4Mfc4yfjDmUO8x/e8N+dOcbpLj6VzHVxumK4DV644 N0MvFz0fyM5oEMF4rhkDKxD6LHmD9ui5aLlV8gREpzn5/ASLHvGiTSf5YXu6t+WiE7brYT7QbNHm +/pe7R20nqA1W6GSy/BJkv6FCgU+5tkL4k+73JU3/JHpMjUi0R86TieFnbAVlDLaYQ1HTWBCrpJH 6INaUFjpiou5XaHc3ZlKHzZnu0jkg7Y360g6rw9njxcH6ATK72oxh9TAtvmUcXtnZLi2kUpCe2Uu MGoM9ZDulebyzYLs2aFK7PayS+VFheZteJMELpyCbTapxDFkH4aDCyr0NQp4yVXPQbBH6TCfmb5h qAaEuSh6XzjZG6k4sIN/c8HDO0gqgg8hm7jMqDXDhBuDsz6+pJVpATqJAHgE2cn0mRmrVn5bi4Y5 FZGkECwJMoBgs5PAKrYYC51+jUnyEEp/+dVGLxmSo5mnJqy7jDzmDrxHB9xzUfFwZC8I+bRHHTBs ROopN4WSaGa8gzj+ezku01DwH/teYLappvonQfGbGHLy9YR0SslnxFSuSGTfjNFusB3hB48IHpmc celM2KX3RxIfdNFRnobzwqIjQAtz20um53MGjMGg6cFZrEb65i/4z3GcRm25xBWNOHkDRUjvxF3X CO6HOSKGsg0PWEP3calILv3q1h8CAwEAAaOBrDCBqTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/ BAUwAwEB/zAdBgNVHQ4EFgQUF6DNweRBtjpbO8tFnb0cwpj6hlgwHwYDVR0jBBgwFoAUF6DNweRB tjpbO8tFnb0cwpj6hlgwRgYDVR0gBD8wPTA7BglghXQBWQEDAQEwLjAsBggrBgEFBQcCARYgaHR0 cDovL3JlcG9zaXRvcnkuc3dpc3NzaWduLmNvbS8wDQYJKoZIhvcNAQEFBQADggIBAHPGgeAn0i0P 4JUw4ppBf1AsX19iYamGamkYDHRJ1l2E6kFSGG9YrVBWIGrGvShpWJHckRE1qTodvBqlYJ7YH39F kWnZfrt4csEGDyrOj4VwYaygzQu4OSlWhDJOhrs9xCrZ1x9y7v5RoSJBsXECYxqCsGKrXlcSH9/L 3XWgwF15kIwb4FDm3jH+mHtwX6WQ2K34ArZv02DdQEsixT2tOnqfGhpHkXkzuoLcMmkDlm4fS/Bx /uNncqCxv1yL5PqZIseEuRuNI5c/7SXgz2W79WEE790eslpBIlqhn10s6FvJbakMDHiqYMZWjwFa DGi8aRl5xB9+lwW/xekkUV7U1UtT7dkjWjYDZaPBA61BMPNGG4WQr2W11bHkFlt4dR2Xem1ZqSqP e97Dh4kQmUlzeMg9vVE1dCrV8X5pGyq7O70luJpaPXJhkGaH7gzWTdQRdAtq/gsD/KNVV4n+Ssuu WxcFyPKNIzFTONItaj+CuY0IavdeQXRuwxF+B6wpYJE/OMpXEA29MC/HpeZBoNquBYeaoKRlbEwJ DIm6uNO5wJOKMPqN5ZprFQFOZ6raYlY+hAhm0sQ2fac+EPyI4NSA5QC9qvNOBqN6avlicuMJT+ub DgEj8Z+7fNzcbBGXJbLytGMU0gYqZ4yD9c7qB9iaah7s5Aq7KkzrCWA5zspi2C5u -----END CERTIFICATE----- GeoTrust Primary Certification Authority ======================================== -----BEGIN CERTIFICATE----- MIIDfDCCAmSgAwIBAgIQGKy1av1pthU6Y2yv2vrEoTANBgkqhkiG9w0BAQUFADBYMQswCQYDVQQG EwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjExMC8GA1UEAxMoR2VvVHJ1c3QgUHJpbWFyeSBD ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNjExMjcwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMFgx CzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTEwLwYDVQQDEyhHZW9UcnVzdCBQ cmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB CgKCAQEAvrgVe//UfH1nrYNke8hCUy3f9oQIIGHWAVlqnEQRr+92/ZV+zmEwu3qDXwK9AWbK7hWN b6EwnL2hhZ6UOvNWiAAxz9juapYC2e0DjPt1befquFUWBRaa9OBesYjAZIVcFU2Ix7e64HXprQU9 nceJSOC7KMgD4TCTZF5SwFlwIjVXiIrxlQqD17wxcwE07e9GceBrAqg1cmuXm2bgyxx5X9gaBGge RwLmnWDiNpcB3841kt++Z8dtd1k7j53WkBWUvEI0EME5+bEnPn7WinXFsq+W06Lem+SYvn3h6YGt tm/81w7a4DSwDRp35+MImO9Y+pyEtzavwt+s0vQQBnBxNQIDAQABo0IwQDAPBgNVHRMBAf8EBTAD AQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQULNVQQZcVi/CPNmFbSvtr2ZnJM5IwDQYJKoZI hvcNAQEFBQADggEBAFpwfyzdtzRP9YZRqSa+S7iq8XEN3GHHoOo0Hnp3DwQ16CePbJC/kRYkRj5K Ts4rFtULUh38H2eiAkUxT87z+gOneZ1TatnaYzr4gNfTmeGl4b7UVXGYNTq+k+qurUKykG/g/CFN NWMziUnWm07Kx+dOCQD32sfvmWKZd7aVIl6KoKv0uHiYyjgZmclynnjNS6yvGaBzEi38wkG6gZHa Floxt/m0cYASSJlyc1pZU8FjUjPtp8nSOQJw+uCxQmYpqptR7TBUIhRf2asdweSU8Pj1K/fqynhG 1riR/aYNKxoUAT6A8EKglQdebc3MS6RFjasS6LPeWuWgfOgPIh1a6Vk= -----END CERTIFICATE----- thawte Primary Root CA ====================== -----BEGIN CERTIFICATE----- MIIEIDCCAwigAwIBAgIQNE7VVyDV7exJ9C/ON9srbTANBgkqhkiG9w0BAQUFADCBqTELMAkGA1UE BhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2 aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIwMDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhv cml6ZWQgdXNlIG9ubHkxHzAdBgNVBAMTFnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwHhcNMDYxMTE3 MDAwMDAwWhcNMzYwNzE2MjM1OTU5WjCBqTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwg SW5jLjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMv KGMpIDIwMDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxHzAdBgNVBAMT FnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCs oPD7gFnUnMekz52hWXMJEEUMDSxuaPFsW0hoSVk3/AszGcJ3f8wQLZU0HObrTQmnHNK4yZc2AreJ 1CRfBsDMRJSUjQJib+ta3RGNKJpchJAQeg29dGYvajig4tVUROsdB58Hum/u6f1OCyn1PoSgAfGc q/gcfomk6KHYcWUNo1F77rzSImANuVud37r8UVsLr5iy6S7pBOhih94ryNdOwUxkHt3Ph1i6Sk/K aAcdHJ1KxtUvkcx8cXIcxcBn6zL9yZJclNqFwJu/U30rCfSMnZEfl2pSy94JNqR32HuHUETVPm4p afs5SSYeCaWAe0At6+gnhcn+Yf1+5nyXHdWdAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYD VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBR7W0XPr87Lev0xkhpqtvNG61dIUDANBgkqhkiG9w0BAQUF AAOCAQEAeRHAS7ORtvzw6WfUDW5FvlXok9LOAz/t2iWwHVfLHjp2oEzsUHboZHIMpKnxuIvW1oeE uzLlQRHAd9mzYJ3rG9XRbkREqaYB7FViHXe4XI5ISXycO1cRrK1zN44veFyQaEfZYGDm/Ac9IiAX xPcW6cTYcvnIc3zfFi8VqT79aie2oetaupgf1eNNZAqdE8hhuvU5HIe6uL17In/2/qxAeeWsEG89 jxt5dovEN7MhGITlNgDrYyCZuen+MwS7QcjBAvlEYyCegc5C09Y/LHbTY5xZ3Y+m4Q6gLkH3LpVH z7z9M/P2C2F+fpErgUfCJzDupxBdN49cOSvkBPB7jVaMaA== -----END CERTIFICATE----- VeriSign Class 3 Public Primary Certification Authority - G5 ============================================================ -----BEGIN CERTIFICATE----- MIIE0zCCA7ugAwIBAgIQGNrRniZ96LtKIVjNzGs7SjANBgkqhkiG9w0BAQUFADCByjELMAkGA1UE BhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBUcnVzdCBO ZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVk IHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRp ZmljYXRpb24gQXV0aG9yaXR5IC0gRzUwHhcNMDYxMTA4MDAwMDAwWhcNMzYwNzE2MjM1OTU5WjCB yjELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2ln biBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJpU2lnbiwgSW5jLiAtIEZvciBh dXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmlt YXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAw ggEKAoIBAQCvJAgIKXo1nmAMqudLO07cfLw8RRy7K+D+KQL5VwijZIUVJ/XxrcgxiV0i6CqqpkKz j/i5Vbext0uz/o9+B1fs70PbZmIVYc9gDaTY3vjgw2IIPVQT60nKWVSFJuUrjxuf6/WhkcIzSdhD Y2pSS9KP6HBRTdGJaXvHcPaz3BJ023tdS1bTlr8Vd6Gw9KIl8q8ckmcY5fQGBO+QueQA5N06tRn/ Arr0PO7gi+s3i+z016zy9vA9r911kTMZHRxAy3QkGSGT2RT+rCpSx4/VBEnkjWNHiDxpg8v+R70r fk/Fla4OndTRQ8Bnc+MUCH7lP59zuDMKz10/NIeWiu5T6CUVAgMBAAGjgbIwga8wDwYDVR0TAQH/ BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJaW1hZ2Uv Z2lmMCEwHzAHBgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYjaHR0cDovL2xvZ28udmVy aXNpZ24uY29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFH/TZafC3ey78DAJ80M5+gKvMzEzMA0GCSqG SIb3DQEBBQUAA4IBAQCTJEowX2LP2BqYLz3q3JktvXf2pXkiOOzEp6B4Eq1iDkVwZMXnl2YtmAl+ X6/WzChl8gGqCBpH3vn5fJJaCGkgDdk+bW48DW7Y5gaRQBi5+MHt39tBquCWIMnNZBU4gcmU7qKE KQsTb47bDN0lAtukixlE0kF6BWlKWE9gyn6CagsCqiUXObXbf+eEZSqVir2G3l6BFoMtEMze/aiC Km0oHw0LxOXnGiYZ4fQRbxC1lfznQgUy286dUV4otp6F01vvpX1FQHKOtw5rDgb7MzVIcbidJ4vE ZV8NhnacRHr2lVz2XTIIM6RUthg/aFzyQkqFOFSDX9HoLPKsEdao7WNq -----END CERTIFICATE----- SecureTrust CA ============== -----BEGIN CERTIFICATE----- MIIDuDCCAqCgAwIBAgIQDPCOXAgWpa1Cf/DrJxhZ0DANBgkqhkiG9w0BAQUFADBIMQswCQYDVQQG EwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24xFzAVBgNVBAMTDlNlY3VyZVRy dXN0IENBMB4XDTA2MTEwNzE5MzExOFoXDTI5MTIzMTE5NDA1NVowSDELMAkGA1UEBhMCVVMxIDAe BgNVBAoTF1NlY3VyZVRydXN0IENvcnBvcmF0aW9uMRcwFQYDVQQDEw5TZWN1cmVUcnVzdCBDQTCC ASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKukgeWVzfX2FI7CT8rU4niVWJxB4Q2ZQCQX OZEzZum+4YOvYlyJ0fwkW2Gz4BERQRwdbvC4u/jep4G6pkjGnx29vo6pQT64lO0pGtSO0gMdA+9t DWccV9cGrcrI9f4Or2YlSASWC12juhbDCE/RRvgUXPLIXgGZbf2IzIaowW8xQmxSPmjL8xk037uH GFaAJsTQ3MBv396gwpEWoGQRS0S8Hvbn+mPeZqx2pHGj7DaUaHp3pLHnDi+BeuK1cobvomuL8A/b 01k/unK8RCSc43Oz969XL0Imnal0ugBS8kvNU3xHCzaFDmapCJcWNFfBZveA4+1wVMeT4C4oFVmH ursCAwEAAaOBnTCBmjATBgkrBgEEAYI3FAIEBh4EAEMAQTALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/ BAUwAwEB/zAdBgNVHQ4EFgQUQjK2FvoE/f5dS3rD/fdMQB1aQ68wNAYDVR0fBC0wKzApoCegJYYj aHR0cDovL2NybC5zZWN1cmV0cnVzdC5jb20vU1RDQS5jcmwwEAYJKwYBBAGCNxUBBAMCAQAwDQYJ KoZIhvcNAQEFBQADggEBADDtT0rhWDpSclu1pqNlGKa7UTt36Z3q059c4EVlew3KW+JwULKUBRSu SceNQQcSc5R+DCMh/bwQf2AQWnL1mA6s7Ll/3XpvXdMc9P+IBWlCqQVxyLesJugutIxq/3HcuLHf mbx8IVQr5Fiiu1cprp6poxkmD5kuCLDv/WnPmRoJjeOnnyvJNjR7JLN4TJUXpAYmHrZkUjZfYGfZ nMUFdAvnZyPSCPyI6a6Lf+Ew9Dd+/cYy2i2eRDAwbO4H3tI0/NL/QPZL9GZGBlSm8jIKYyYwa5vR 3ItHuuG51WLQoqD0ZwV4KWMabwTW+MZMo5qxN7SN5ShLHZ4swrhovO0C7jE= -----END CERTIFICATE----- Secure Global CA ================ -----BEGIN CERTIFICATE----- MIIDvDCCAqSgAwIBAgIQB1YipOjUiolN9BPI8PjqpTANBgkqhkiG9w0BAQUFADBKMQswCQYDVQQG EwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24xGTAXBgNVBAMTEFNlY3VyZSBH bG9iYWwgQ0EwHhcNMDYxMTA3MTk0MjI4WhcNMjkxMjMxMTk1MjA2WjBKMQswCQYDVQQGEwJVUzEg MB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24xGTAXBgNVBAMTEFNlY3VyZSBHbG9iYWwg Q0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvNS7YrGxVaQZx5RNoJLNP2MwhR/jx YDiJiQPpvepeRlMJ3Fz1Wuj3RSoC6zFh1ykzTM7HfAo3fg+6MpjhHZevj8fcyTiW89sa/FHtaMbQ bqR8JNGuQsiWUGMu4P51/pinX0kuleM5M2SOHqRfkNJnPLLZ/kG5VacJjnIFHovdRIWCQtBJwB1g 8NEXLJXr9qXBkqPFwqcIYA1gBBCWeZ4WNOaptvolRTnIHmX5k/Wq8VLcmZg9pYYaDDUz+kulBAYV HDGA76oYa8J719rO+TMg1fW9ajMtgQT7sFzUnKPiXB3jqUJ1XnvUd+85VLrJChgbEplJL4hL/VBi 0XPnj3pDAgMBAAGjgZ0wgZowEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0PBAQDAgGGMA8GA1Ud EwEB/wQFMAMBAf8wHQYDVR0OBBYEFK9EBMJBfkiD2045AuzshHrmzsmkMDQGA1UdHwQtMCswKaAn oCWGI2h0dHA6Ly9jcmwuc2VjdXJldHJ1c3QuY29tL1NHQ0EuY3JsMBAGCSsGAQQBgjcVAQQDAgEA MA0GCSqGSIb3DQEBBQUAA4IBAQBjGghAfaReUw132HquHw0LURYD7xh8yOOvaliTFGCRsoTciE6+ OYo68+aCiV0BN7OrJKQVDpI1WkpEXk5X+nXOH0jOZvQ8QCaSmGwb7iRGDBezUqXbpZGRzzfTb+cn CDpOGR86p1hcF895P4vkp9MmI50mD1hp/Ed+stCNi5O/KU9DaXR2Z0vPB4zmAve14bRDtUstFJ/5 3CYNv6ZHdAbYiNE6KTCEztI5gGIbqMdXSbxqVVFnFUq+NQfk1XWYN3kwFNspnWzFacxHVaIw98xc f8LDmBxrThaA63p4ZUWiABqvDA1VZDRIuJK58bRQKfJPIx/abKwfROHdI3hRW8cW -----END CERTIFICATE----- COMODO Certification Authority ============================== -----BEGIN CERTIFICATE----- MIIEHTCCAwWgAwIBAgIQToEtioJl4AsC7j41AkblPTANBgkqhkiG9w0BAQUFADCBgTELMAkGA1UE BhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgG A1UEChMRQ09NT0RPIENBIExpbWl0ZWQxJzAlBgNVBAMTHkNPTU9ETyBDZXJ0aWZpY2F0aW9uIEF1 dGhvcml0eTAeFw0wNjEyMDEwMDAwMDBaFw0yOTEyMzEyMzU5NTlaMIGBMQswCQYDVQQGEwJHQjEb MBkGA1UECBMSR3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHEwdTYWxmb3JkMRowGAYDVQQKExFD T01PRE8gQ0EgTGltaXRlZDEnMCUGA1UEAxMeQ09NT0RPIENlcnRpZmljYXRpb24gQXV0aG9yaXR5 MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0ECLi3LjkRv3UcEbVASY06m/weaKXTuH +7uIzg3jLz8GlvCiKVCZrts7oVewdFFxze1CkU1B/qnI2GqGd0S7WWaXUF601CxwRM/aN5VCaTww xHGzUvAhTaHYujl8HJ6jJJ3ygxaYqhZ8Q5sVW7euNJH+1GImGEaaP+vB+fGQV+useg2L23IwambV 4EajcNxo2f8ESIl33rXp+2dtQem8Ob0y2WIC8bGoPW43nOIv4tOiJovGuFVDiOEjPqXSJDlqR6sA 1KGzqSX+DT+nHbrTUcELpNqsOO9VUCQFZUaTNE8tja3G1CEZ0o7KBWFxB3NH5YoZEr0ETc5OnKVI rLsm9wIDAQABo4GOMIGLMB0GA1UdDgQWBBQLWOWLxkwVN6RAqTCpIb5HNlpW/zAOBgNVHQ8BAf8E BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zBJBgNVHR8EQjBAMD6gPKA6hjhodHRwOi8vY3JsLmNvbW9k b2NhLmNvbS9DT01PRE9DZXJ0aWZpY2F0aW9uQXV0aG9yaXR5LmNybDANBgkqhkiG9w0BAQUFAAOC AQEAPpiem/Yb6dc5t3iuHXIYSdOH5EOC6z/JqvWote9VfCFSZfnVDeFs9D6Mk3ORLgLETgdxb8CP OGEIqB6BCsAvIC9Bi5HcSEW88cbeunZrM8gALTFGTO3nnc+IlP8zwFboJIYmuNg4ON8qa90SzMc/ RxdMosIGlgnW2/4/PEZB31jiVg88O8EckzXZOFKs7sjsLjBOlDW0JB9LeGna8gI4zJVSk/BwJVmc IGfE7vmLV2H0knZ9P4SNVbfo5azV8fUZVqZa+5Acr5Pr5RzUZ5ddBA6+C4OmF4O5MBKgxTMVBbkN +8cFduPYSo38NBejxiEovjBFMR7HeL5YYTisO+IBZQ== -----END CERTIFICATE----- Network Solutions Certificate Authority ======================================= -----BEGIN CERTIFICATE----- MIID5jCCAs6gAwIBAgIQV8szb8JcFuZHFhfjkDFo4DANBgkqhkiG9w0BAQUFADBiMQswCQYDVQQG EwJVUzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMuMTAwLgYDVQQDEydOZXR3b3Jr IFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwHhcNMDYxMjAxMDAwMDAwWhcNMjkxMjMx MjM1OTU5WjBiMQswCQYDVQQGEwJVUzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMu MTAwLgYDVQQDEydOZXR3b3JrIFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEiMA0G CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDkvH6SMG3G2I4rC7xGzuAnlt7e+foS0zwzc7MEL7xx jOWftiJgPl9dzgn/ggwbmlFQGiaJ3dVhXRncEg8tCqJDXRfQNJIg6nPPOCwGJgl6cvf6UDL4wpPT aaIjzkGxzOTVHzbRijr4jGPiFFlp7Q3Tf2vouAPlT2rlmGNpSAW+Lv8ztumXWWn4Zxmuk2GWRBXT crA/vGp97Eh/jcOrqnErU2lBUzS1sLnFBgrEsEX1QV1uiUV7PTsmjHTC5dLRfbIR1PtYMiKagMnc /Qzpf14Dl847ABSHJ3A4qY5usyd2mFHgBeMhqxrVhSI8KbWaFsWAqPS7azCPL0YCorEMIuDTAgMB AAGjgZcwgZQwHQYDVR0OBBYEFCEwyfsA106Y2oeqKtCnLrFAMadMMA4GA1UdDwEB/wQEAwIBBjAP BgNVHRMBAf8EBTADAQH/MFIGA1UdHwRLMEkwR6BFoEOGQWh0dHA6Ly9jcmwubmV0c29sc3NsLmNv bS9OZXR3b3JrU29sdXRpb25zQ2VydGlmaWNhdGVBdXRob3JpdHkuY3JsMA0GCSqGSIb3DQEBBQUA A4IBAQC7rkvnt1frf6ott3NHhWrB5KUd5Oc86fRZZXe1eltajSU24HqXLjjAV2CDmAaDn7l2em5Q 4LqILPxFzBiwmZVRDuwduIj/h1AcgsLj4DKAv6ALR8jDMe+ZZzKATxcheQxpXN5eNK4CtSbqUN9/ GGUsyfJj4akH/nxxH2szJGoeBfcFaMBqEssuXmHLrijTfsK0ZpEmXzwuJF/LWA/rKOyvEZbz3Htv wKeI8lN3s2Berq4o2jUsbzRF0ybh3uxbTydrFny9RAQYgrOJeRcQcT16ohZO9QHNpGxlaKFJdlxD ydi8NmdspZS11My5vWo1ViHe2MPr+8ukYEywVaCge1ey -----END CERTIFICATE----- WellsSecure Public Root Certificate Authority ============================================= -----BEGIN CERTIFICATE----- MIIEvTCCA6WgAwIBAgIBATANBgkqhkiG9w0BAQUFADCBhTELMAkGA1UEBhMCVVMxIDAeBgNVBAoM F1dlbGxzIEZhcmdvIFdlbGxzU2VjdXJlMRwwGgYDVQQLDBNXZWxscyBGYXJnbyBCYW5rIE5BMTYw NAYDVQQDDC1XZWxsc1NlY3VyZSBQdWJsaWMgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwHhcN MDcxMjEzMTcwNzU0WhcNMjIxMjE0MDAwNzU0WjCBhTELMAkGA1UEBhMCVVMxIDAeBgNVBAoMF1dl bGxzIEZhcmdvIFdlbGxzU2VjdXJlMRwwGgYDVQQLDBNXZWxscyBGYXJnbyBCYW5rIE5BMTYwNAYD VQQDDC1XZWxsc1NlY3VyZSBQdWJsaWMgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEiMA0G CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDub7S9eeKPCCGeOARBJe+rWxxTkqxtnt3CxC5FlAM1 iGd0V+PfjLindo8796jE2yljDpFoNoqXjopxaAkH5OjUDk/41itMpBb570OYj7OeUt9tkTmPOL13 i0Nj67eT/DBMHAGTthP796EfvyXhdDcsHqRePGj4S78NuR4uNuip5Kf4D8uCdXw1LSLWwr8L87T8 bJVhHlfXBIEyg1J55oNjz7fLY4sR4r1e6/aN7ZVyKLSsEmLpSjPmgzKuBXWVvYSV2ypcm44uDLiB K0HmOFafSZtsdvqKXfcBeYF8wYNABf5x/Qw/zE5gCQ5lRxAvAcAFP4/4s0HvWkJ+We/SlwxlAgMB AAGjggE0MIIBMDAPBgNVHRMBAf8EBTADAQH/MDkGA1UdHwQyMDAwLqAsoCqGKGh0dHA6Ly9jcmwu cGtpLndlbGxzZmFyZ28uY29tL3dzcHJjYS5jcmwwDgYDVR0PAQH/BAQDAgHGMB0GA1UdDgQWBBQm lRkQ2eihl5H/3BnZtQQ+0nMKajCBsgYDVR0jBIGqMIGngBQmlRkQ2eihl5H/3BnZtQQ+0nMKaqGB i6SBiDCBhTELMAkGA1UEBhMCVVMxIDAeBgNVBAoMF1dlbGxzIEZhcmdvIFdlbGxzU2VjdXJlMRww GgYDVQQLDBNXZWxscyBGYXJnbyBCYW5rIE5BMTYwNAYDVQQDDC1XZWxsc1NlY3VyZSBQdWJsaWMg Um9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHmCAQEwDQYJKoZIhvcNAQEFBQADggEBALkVsUSRzCPI K0134/iaeycNzXK7mQDKfGYZUMbVmO2rvwNa5U3lHshPcZeG1eMd/ZDJPHV3V3p9+N701NX3leZ0 bh08rnyd2wIDBSxxSyU+B+NemvVmFymIGjifz6pBA4SXa5M4esowRBskRDPQ5NHcKDj0E0M1NSlj qHyita04pO2t/caaH/+Xc/77szWnk4bGdpEA5qxRFsQnMlzbc9qlk1eOPm01JghZ1edE13YgY+es E2fDbbFwRnzVlhE9iW9dqKHrjQrawx0zbKPqZxmamX9LPYNRKh3KL4YMon4QLSvUFpULB6ouFJJJ tylv2G0xffX8oRAHh84vWdw+WNs= -----END CERTIFICATE----- COMODO ECC Certification Authority ================================== -----BEGIN CERTIFICATE----- MIICiTCCAg+gAwIBAgIQH0evqmIAcFBUTAGem2OZKjAKBggqhkjOPQQDAzCBhTELMAkGA1UEBhMC R0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UE ChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBB dXRob3JpdHkwHhcNMDgwMzA2MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0Ix GzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMR Q09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRo b3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQDR3svdcmCFYX7deSRFtSrYpn1PlILBs5BAH+X 4QokPB0BBO490o0JlwzgdeT6+3eKKvUDYEs2ixYjFq0JcfRK9ChQtP6IHG4/bC8vCVlbpVsLM5ni wz2J+Wos77LTBumjQjBAMB0GA1UdDgQWBBR1cacZSBm8nZ3qQUfflMRId5nTeTAOBgNVHQ8BAf8E BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjEA7wNbeqy3eApyt4jf/7VG FAkK+qDmfQjGGoe9GKhzvSbKYAydzpmfz1wPMOG+FDHqAjAU9JM8SaczepBGR7NjfRObTrdvGDeA U/7dIOA1mjbRxwG55tzd8/8dLDoWV9mSOdY= -----END CERTIFICATE----- IGC/A ===== -----BEGIN CERTIFICATE----- MIIEAjCCAuqgAwIBAgIFORFFEJQwDQYJKoZIhvcNAQEFBQAwgYUxCzAJBgNVBAYTAkZSMQ8wDQYD VQQIEwZGcmFuY2UxDjAMBgNVBAcTBVBhcmlzMRAwDgYDVQQKEwdQTS9TR0ROMQ4wDAYDVQQLEwVE Q1NTSTEOMAwGA1UEAxMFSUdDL0ExIzAhBgkqhkiG9w0BCQEWFGlnY2FAc2dkbi5wbS5nb3V2LmZy MB4XDTAyMTIxMzE0MjkyM1oXDTIwMTAxNzE0MjkyMlowgYUxCzAJBgNVBAYTAkZSMQ8wDQYDVQQI EwZGcmFuY2UxDjAMBgNVBAcTBVBhcmlzMRAwDgYDVQQKEwdQTS9TR0ROMQ4wDAYDVQQLEwVEQ1NT STEOMAwGA1UEAxMFSUdDL0ExIzAhBgkqhkiG9w0BCQEWFGlnY2FAc2dkbi5wbS5nb3V2LmZyMIIB IjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsh/R0GLFMzvABIaIs9z4iPf930Pfeo2aSVz2 TqrMHLmh6yeJ8kbpO0px1R2OLc/mratjUMdUC24SyZA2xtgv2pGqaMVy/hcKshd+ebUyiHDKcMCW So7kVc0dJ5S/znIq7Fz5cyD+vfcuiWe4u0dzEvfRNWk68gq5rv9GQkaiv6GFGvm/5P9JhfejcIYy HF2fYPepraX/z9E0+X1bF8bc1g4oa8Ld8fUzaJ1O/Id8NhLWo4DoQw1VYZTqZDdH6nfK0LJYBcNd frGoRpAxVs5wKpayMLh35nnAvSk7/ZR3TL0gzUEl4C7HG7vupARB0l2tEmqKm0f7yd1GQOGdPDPQ tQIDAQABo3cwdTAPBgNVHRMBAf8EBTADAQH/MAsGA1UdDwQEAwIBRjAVBgNVHSAEDjAMMAoGCCqB egF5AQEBMB0GA1UdDgQWBBSjBS8YYFDCiQrdKyFP/45OqDAxNjAfBgNVHSMEGDAWgBSjBS8YYFDC iQrdKyFP/45OqDAxNjANBgkqhkiG9w0BAQUFAAOCAQEABdwm2Pp3FURo/C9mOnTgXeQp/wYHE4RK q89toB9RlPhJy3Q2FLwV3duJL92PoF189RLrn544pEfMs5bZvpwlqwN+Mw+VgQ39FuCIvjfwbF3Q MZsyK10XZZOYYLxuj7GoPB7ZHPOpJkL5ZB3C55L29B5aqhlSXa/oovdgoPaN8In1buAKBQGVyYsg Crpa/JosPL3Dt8ldeCUFP1YUmwza+zpI/pdpXsoQhvdOlgQITeywvl3cO45Pwf2aNjSaTFR+FwNI lQgRHAdvhQh+XU3Endv7rs6y0bO4g2wdsrN58dhwmX7wEwLOXt1R0982gaEbeC9xs/FZTEYYKKuF 0mBWWg== -----END CERTIFICATE----- Security Communication EV RootCA1 ================================= -----BEGIN CERTIFICATE----- MIIDfTCCAmWgAwIBAgIBADANBgkqhkiG9w0BAQUFADBgMQswCQYDVQQGEwJKUDElMCMGA1UEChMc U0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEqMCgGA1UECxMhU2VjdXJpdHkgQ29tbXVuaWNh dGlvbiBFViBSb290Q0ExMB4XDTA3MDYwNjAyMTIzMloXDTM3MDYwNjAyMTIzMlowYDELMAkGA1UE BhMCSlAxJTAjBgNVBAoTHFNFQ09NIFRydXN0IFN5c3RlbXMgQ08uLExURC4xKjAoBgNVBAsTIVNl Y3VyaXR5IENvbW11bmljYXRpb24gRVYgUm9vdENBMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC AQoCggEBALx/7FebJOD+nLpCeamIivqA4PUHKUPqjgo0No0c+qe1OXj/l3X3L+SqawSERMqm4miO /VVQYg+kcQ7OBzgtQoVQrTyWb4vVog7P3kmJPdZkLjjlHmy1V4qe70gOzXppFodEtZDkBp2uoQSX WHnvIEqCa4wiv+wfD+mEce3xDuS4GBPMVjZd0ZoeUWs5bmB2iDQL87PRsJ3KYeJkHcFGB7hj3R4z ZbOOCVVSPbW9/wfrrWFVGCypaZhKqkDFMxRldAD5kd6vA0jFQFTcD4SQaCDFkpbcLuUCRarAX1T4 bepJz11sS6/vmsJWXMY1VkJqMF/Cq/biPT+zyRGPMUzXn0kCAwEAAaNCMEAwHQYDVR0OBBYEFDVK 9U2vP9eCOKyrcWUXdYydVZPmMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MA0GCSqG SIb3DQEBBQUAA4IBAQCoh+ns+EBnXcPBZsdAS5f8hxOQWsTvoMpfi7ent/HWtWS3irO4G8za+6xm iEHO6Pzk2x6Ipu0nUBsCMCRGef4Eh3CXQHPRwMFXGZpppSeZq51ihPZRwSzJIxXYKLerJRO1RuGG Av8mjMSIkh1W/hln8lXkgKNrnKt34VFxDSDbEJrbvXZ5B3eZKK2aXtqxT0QsNY6llsf9g/BYxnnW mHyojf6GPgcWkuF75x3sM3Z+Qi5KhfmRiWiEA4Glm5q+4zfFVKtWOxgtQaQM+ELbmaDgcm+7XeEW T1MKZPlO9L9OVL14bIjqv5wTJMJwaaJ/D8g8rQjJsJhAoyrniIPtd490 -----END CERTIFICATE----- OISTE WISeKey Global Root GA CA =============================== -----BEGIN CERTIFICATE----- MIID8TCCAtmgAwIBAgIQQT1yx/RrH4FDffHSKFTfmjANBgkqhkiG9w0BAQUFADCBijELMAkGA1UE BhMCQ0gxEDAOBgNVBAoTB1dJU2VLZXkxGzAZBgNVBAsTEkNvcHlyaWdodCAoYykgMjAwNTEiMCAG A1UECxMZT0lTVEUgRm91bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBH bG9iYWwgUm9vdCBHQSBDQTAeFw0wNTEyMTExNjAzNDRaFw0zNzEyMTExNjA5NTFaMIGKMQswCQYD VQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEbMBkGA1UECxMSQ29weXJpZ2h0IChjKSAyMDA1MSIw IAYDVQQLExlPSVNURSBGb3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5 IEdsb2JhbCBSb290IEdBIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAy0+zAJs9 Nt350UlqaxBJH+zYK7LG+DKBKUOVTJoZIyEVRd7jyBxRVVuuk+g3/ytr6dTqvirdqFEr12bDYVxg Asj1znJ7O7jyTmUIms2kahnBAbtzptf2w93NvKSLtZlhuAGio9RN1AU9ka34tAhxZK9w8RxrfvbD d50kc3vkDIzh2TbhmYsFmQvtRTEJysIA2/dyoJaqlYfQjse2YXMNdmaM3Bu0Y6Kff5MTMPGhJ9vZ /yxViJGg4E8HsChWjBgbl0SOid3gF27nKu+POQoxhILYQBRJLnpB5Kf+42TMwVlxSywhp1t94B3R LoGbw9ho972WG6xwsRYUC9tguSYBBQIDAQABo1EwTzALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUw AwEB/zAdBgNVHQ4EFgQUswN+rja8sHnR3JQmthG+IbJphpQwEAYJKwYBBAGCNxUBBAMCAQAwDQYJ KoZIhvcNAQEFBQADggEBAEuh/wuHbrP5wUOxSPMowB0uyQlB+pQAHKSkq0lPjz0e701vvbyk9vIm MMkQyh2I+3QZH4VFvbBsUfk2ftv1TDI6QU9bR8/oCy22xBmddMVHxjtqD6wU2zz0c5ypBd8A3HR4 +vg1YFkCExh8vPtNsCBtQ7tgMHpnM1zFmdH4LTlSc/uMqpclXHLZCB6rTjzjgTGfA6b7wP4piFXa hNVQA7bihKOmNqoROgHhGEvWRGizPflTdISzRpFGlgC3gCy24eMQ4tui5yiPAZZiFj4A4xylNoEY okxSdsARo27mHbrjWr42U8U+dY+GaSlYU7Wcu2+fXMUY7N0v4ZjJ/L7fCg0= -----END CERTIFICATE----- Microsec e-Szigno Root CA ========================= -----BEGIN CERTIFICATE----- MIIHqDCCBpCgAwIBAgIRAMy4579OKRr9otxmpRwsDxEwDQYJKoZIhvcNAQEFBQAwcjELMAkGA1UE BhMCSFUxETAPBgNVBAcTCEJ1ZGFwZXN0MRYwFAYDVQQKEw1NaWNyb3NlYyBMdGQuMRQwEgYDVQQL EwtlLVN6aWdubyBDQTEiMCAGA1UEAxMZTWljcm9zZWMgZS1Temlnbm8gUm9vdCBDQTAeFw0wNTA0 MDYxMjI4NDRaFw0xNzA0MDYxMjI4NDRaMHIxCzAJBgNVBAYTAkhVMREwDwYDVQQHEwhCdWRhcGVz dDEWMBQGA1UEChMNTWljcm9zZWMgTHRkLjEUMBIGA1UECxMLZS1Temlnbm8gQ0ExIjAgBgNVBAMT GU1pY3Jvc2VjIGUtU3ppZ25vIFJvb3QgQ0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB AQDtyADVgXvNOABHzNuEwSFpLHSQDCHZU4ftPkNEU6+r+ICbPHiN1I2uuO/TEdyB5s87lozWbxXG d36hL+BfkrYn13aaHUM86tnsL+4582pnS4uCzyL4ZVX+LMsvfUh6PXX5qqAnu3jCBspRwn5mS6/N oqdNAoI/gqyFxuEPkEeZlApxcpMqyabAvjxWTHOSJ/FrtfX9/DAFYJLG65Z+AZHCabEeHXtTRbjc QR/Ji3HWVBTji1R4P770Yjtb9aPs1ZJ04nQw7wHb4dSrmZsqa/i9phyGI0Jf7Enemotb9HI6QMVJ PqW+jqpx62z69Rrkav17fVVA71hu5tnVvCSrwe+3AgMBAAGjggQ3MIIEMzBnBggrBgEFBQcBAQRb MFkwKAYIKwYBBQUHMAGGHGh0dHBzOi8vcmNhLmUtc3ppZ25vLmh1L29jc3AwLQYIKwYBBQUHMAKG IWh0dHA6Ly93d3cuZS1zemlnbm8uaHUvUm9vdENBLmNydDAPBgNVHRMBAf8EBTADAQH/MIIBcwYD VR0gBIIBajCCAWYwggFiBgwrBgEEAYGoGAIBAQEwggFQMCgGCCsGAQUFBwIBFhxodHRwOi8vd3d3 LmUtc3ppZ25vLmh1L1NaU1ovMIIBIgYIKwYBBQUHAgIwggEUHoIBEABBACAAdABhAG4A+gBzAO0A dAB2AOEAbgB5ACAA6QByAHQAZQBsAG0AZQB6AOkAcwDpAGgAZQB6ACAA6QBzACAAZQBsAGYAbwBn AGEAZADhAHMA4QBoAG8AegAgAGEAIABTAHoAbwBsAGcA4QBsAHQAYQB0APMAIABTAHoAbwBsAGcA 4QBsAHQAYQB0AOEAcwBpACAAUwB6AGEAYgDhAGwAeQB6AGEAdABhACAAcwB6AGUAcgBpAG4AdAAg AGsAZQBsAGwAIABlAGwAagDhAHIAbgBpADoAIABoAHQAdABwADoALwAvAHcAdwB3AC4AZQAtAHMA egBpAGcAbgBvAC4AaAB1AC8AUwBaAFMAWgAvMIHIBgNVHR8EgcAwgb0wgbqggbeggbSGIWh0dHA6 Ly93d3cuZS1zemlnbm8uaHUvUm9vdENBLmNybIaBjmxkYXA6Ly9sZGFwLmUtc3ppZ25vLmh1L0NO PU1pY3Jvc2VjJTIwZS1Temlnbm8lMjBSb290JTIwQ0EsT1U9ZS1Temlnbm8lMjBDQSxPPU1pY3Jv c2VjJTIwTHRkLixMPUJ1ZGFwZXN0LEM9SFU/Y2VydGlmaWNhdGVSZXZvY2F0aW9uTGlzdDtiaW5h cnkwDgYDVR0PAQH/BAQDAgEGMIGWBgNVHREEgY4wgYuBEGluZm9AZS1zemlnbm8uaHWkdzB1MSMw IQYDVQQDDBpNaWNyb3NlYyBlLVN6aWduw7MgUm9vdCBDQTEWMBQGA1UECwwNZS1TemlnbsOzIEhT WjEWMBQGA1UEChMNTWljcm9zZWMgS2Z0LjERMA8GA1UEBxMIQnVkYXBlc3QxCzAJBgNVBAYTAkhV MIGsBgNVHSMEgaQwgaGAFMegSXUWYYTbMUuE0vE3QJDvTtz3oXakdDByMQswCQYDVQQGEwJIVTER MA8GA1UEBxMIQnVkYXBlc3QxFjAUBgNVBAoTDU1pY3Jvc2VjIEx0ZC4xFDASBgNVBAsTC2UtU3pp Z25vIENBMSIwIAYDVQQDExlNaWNyb3NlYyBlLVN6aWdubyBSb290IENBghEAzLjnv04pGv2i3Gal HCwPETAdBgNVHQ4EFgQUx6BJdRZhhNsxS4TS8TdAkO9O3PcwDQYJKoZIhvcNAQEFBQADggEBANMT nGZjWS7KXHAM/IO8VbH0jgdsZifOwTsgqRy7RlRw7lrMoHfqaEQn6/Ip3Xep1fvj1KcExJW4C+FE aGAHQzAxQmHl7tnlJNUb3+FKG6qfx1/4ehHqE5MAyopYse7tDk2016g2JnzgOsHVV4Lxdbb9iV/a 86g4nzUGCM4ilb7N1fy+W955a9x6qWVmvrElWl/tftOsRm1M9DKHtCAE4Gx4sHfRhUZLphK3dehK yVZs15KrnfVJONJPU+NVkBHbmJbGSfI+9J8b4PeI3CVimUTYc78/MPMMNz7UwiiAc7EBt51alhQB S6kRnSlqLtBdgcDPsiBDxwPgN05dCtxZICU= -----END CERTIFICATE----- Certigna ======== -----BEGIN CERTIFICATE----- MIIDqDCCApCgAwIBAgIJAP7c4wEPyUj/MA0GCSqGSIb3DQEBBQUAMDQxCzAJBgNVBAYTAkZSMRIw EAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hMB4XDTA3MDYyOTE1MTMwNVoXDTI3 MDYyOTE1MTMwNVowNDELMAkGA1UEBhMCRlIxEjAQBgNVBAoMCURoaW15b3RpczERMA8GA1UEAwwI Q2VydGlnbmEwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDIaPHJ1tazNHUmgh7stL7q XOEm7RFHYeGifBZ4QCHkYJ5ayGPhxLGWkv8YbWkj4Sti993iNi+RB7lIzw7sebYs5zRLcAglozyH GxnygQcPOJAZ0xH+hrTy0V4eHpbNgGzOOzGTtvKg0KmVEn2lmsxryIRWijOp5yIVUxbwzBfsV1/p ogqYCd7jX5xv3EjjhQsVWqa6n6xI4wmy9/Qy3l40vhx4XUJbzg4ij02Q130yGLMLLGq/jj8UEYkg DncUtT2UCIf3JR7VsmAA7G8qKCVuKj4YYxclPz5EIBb2JsglrgVKtOdjLPOMFlN+XPsRGgjBRmKf Irjxwo1p3Po6WAbfAgMBAAGjgbwwgbkwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUGu3+QTmQ tCRZvgHyUtVF9lo53BEwZAYDVR0jBF0wW4AUGu3+QTmQtCRZvgHyUtVF9lo53BGhOKQ2MDQxCzAJ BgNVBAYTAkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hggkA/tzjAQ/J SP8wDgYDVR0PAQH/BAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIABzANBgkqhkiG9w0BAQUFAAOCAQEA hQMeknH2Qq/ho2Ge6/PAD/Kl1NqV5ta+aDY9fm4fTIrv0Q8hbV6lUmPOEvjvKtpv6zf+EwLHyzs+ ImvaYS5/1HI93TDhHkxAGYwP15zRgzB7mFncfca5DClMoTOi62c6ZYTTluLtdkVwj7Ur3vkj1klu PBS1xp81HlDQwY9qcEQCYsuuHWhBp6pX6FOqB9IG9tUUBguRA3UsbHK1YZWaDYu5Def131TN3ubY 1gkIl2PlwS6wt0QmwCbAr1UwnjvVNioZBPRcHv/PLLf/0P2HQBHVESO7SMAhqaQoLf0V+LBOK/Qw WyH8EZE0vkHve52Xdf+XlcCWWC/qu0bXu+TZLg== -----END CERTIFICATE----- AC Ra\xC3\xADz Certic\xC3\xA1mara S.A. ====================================== -----BEGIN CERTIFICATE----- MIIGZjCCBE6gAwIBAgIPB35Sk3vgFeNX8GmMy+wMMA0GCSqGSIb3DQEBBQUAMHsxCzAJBgNVBAYT AkNPMUcwRQYDVQQKDD5Tb2NpZWRhZCBDYW1lcmFsIGRlIENlcnRpZmljYWNpw7NuIERpZ2l0YWwg LSBDZXJ0aWPDoW1hcmEgUy5BLjEjMCEGA1UEAwwaQUMgUmHDrXogQ2VydGljw6FtYXJhIFMuQS4w HhcNMDYxMTI3MjA0NjI5WhcNMzAwNDAyMjE0MjAyWjB7MQswCQYDVQQGEwJDTzFHMEUGA1UECgw+ U29jaWVkYWQgQ2FtZXJhbCBkZSBDZXJ0aWZpY2FjacOzbiBEaWdpdGFsIC0gQ2VydGljw6FtYXJh IFMuQS4xIzAhBgNVBAMMGkFDIFJhw616IENlcnRpY8OhbWFyYSBTLkEuMIICIjANBgkqhkiG9w0B AQEFAAOCAg8AMIICCgKCAgEAq2uJo1PMSCMI+8PPUZYILrgIem08kBeGqentLhM0R7LQcNzJPNCN yu5LF6vQhbCnIwTLqKL85XXbQMpiiY9QngE9JlsYhBzLfDe3fezTf3MZsGqy2IiKLUV0qPezuMDU 2s0iiXRNWhU5cxh0T7XrmafBHoi0wpOQY5fzp6cSsgkiBzPZkc0OnB8OIMfuuzONj8LSWKdf/WU3 4ojC2I+GdV75LaeHM/J4Ny+LvB2GNzmxlPLYvEqcgxhaBvzz1NS6jBUJJfD5to0EfhcSM2tXSExP 2yYe68yQ54v5aHxwD6Mq0Do43zeX4lvegGHTgNiRg0JaTASJaBE8rF9ogEHMYELODVoqDA+bMMCm 8Ibbq0nXl21Ii/kDwFJnmxL3wvIumGVC2daa49AZMQyth9VXAnow6IYm+48jilSH5L887uvDdUhf HjlvgWJsxS3EF1QZtzeNnDeRyPYL1epjb4OsOMLzP96a++EjYfDIJss2yKHzMI+ko6Kh3VOz3vCa Mh+DkXkwwakfU5tTohVTP92dsxA7SH2JD/ztA/X7JWR1DhcZDY8AFmd5ekD8LVkH2ZD6mq093ICK 5lw1omdMEWux+IBkAC1vImHFrEsm5VoQgpukg3s0956JkSCXjrdCx2bD0Omk1vUgjcTDlaxECp1b czwmPS9KvqfJpxAe+59QafMCAwEAAaOB5jCB4zAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQE AwIBBjAdBgNVHQ4EFgQU0QnQ6dfOeXRU+Tows/RtLAMDG2gwgaAGA1UdIASBmDCBlTCBkgYEVR0g ADCBiTArBggrBgEFBQcCARYfaHR0cDovL3d3dy5jZXJ0aWNhbWFyYS5jb20vZHBjLzBaBggrBgEF BQcCAjBOGkxMaW1pdGFjaW9uZXMgZGUgZ2FyYW507WFzIGRlIGVzdGUgY2VydGlmaWNhZG8gc2Ug cHVlZGVuIGVuY29udHJhciBlbiBsYSBEUEMuMA0GCSqGSIb3DQEBBQUAA4ICAQBclLW4RZFNjmEf AygPU3zmpFmps4p6xbD/CHwso3EcIRNnoZUSQDWDg4902zNc8El2CoFS3UnUmjIz75uny3XlesuX EpBcunvFm9+7OSPI/5jOCk0iAUgHforA1SBClETvv3eiiWdIG0ADBaGJ7M9i4z0ldma/Jre7Ir5v /zlXdLp6yQGVwZVR6Kss+LGGIOk/yzVb0hfpKv6DExdA7ohiZVvVO2Dpezy4ydV/NgIlqmjCMRW3 MGXrfx1IebHPOeJCgBbT9ZMj/EyXyVo3bHwi2ErN0o42gzmRkBDI8ck1fj+404HGIGQatlDCIaR4 3NAvO2STdPCWkPHv+wlaNECW8DYSwaN0jJN+Qd53i+yG2dIPPy3RzECiiWZIHiCznCNZc6lEc7wk eZBWN7PGKX6jD/EpOe9+XCgycDWs2rjIdWb8m0w5R44bb5tNAlQiM+9hup4phO9OSzNHdpdqy35f /RWmnkJDW2ZaiogN9xa5P1FlK2Zqi9E4UqLWRhH6/JocdJ6PlwsCT2TG9WjTSy3/pDceiz+/RL5h RqGEPQgnTIEgd4kI6mdAXmwIUV80WoyWaM3X94nCHNMyAK9Sy9NgWyo6R35rMDOhYil/SrnhLecU Iw4OGEfhefwVVdCx/CVxY3UzHCMrr1zZ7Ud3YA47Dx7SwNxkBYn8eNZcLCZDqQ== -----END CERTIFICATE----- TC TrustCenter Class 2 CA II ============================ -----BEGIN CERTIFICATE----- MIIEqjCCA5KgAwIBAgIOLmoAAQACH9dSISwRXDswDQYJKoZIhvcNAQEFBQAwdjELMAkGA1UEBhMC REUxHDAaBgNVBAoTE1RDIFRydXN0Q2VudGVyIEdtYkgxIjAgBgNVBAsTGVRDIFRydXN0Q2VudGVy IENsYXNzIDIgQ0ExJTAjBgNVBAMTHFRDIFRydXN0Q2VudGVyIENsYXNzIDIgQ0EgSUkwHhcNMDYw MTEyMTQzODQzWhcNMjUxMjMxMjI1OTU5WjB2MQswCQYDVQQGEwJERTEcMBoGA1UEChMTVEMgVHJ1 c3RDZW50ZXIgR21iSDEiMCAGA1UECxMZVEMgVHJ1c3RDZW50ZXIgQ2xhc3MgMiBDQTElMCMGA1UE AxMcVEMgVHJ1c3RDZW50ZXIgQ2xhc3MgMiBDQSBJSTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC AQoCggEBAKuAh5uO8MN8h9foJIIRszzdQ2Lu+MNF2ujhoF/RKrLqk2jftMjWQ+nEdVl//OEd+DFw IxuInie5e/060smp6RQvkL4DUsFJzfb95AhmC1eKokKguNV/aVyQMrKXDcpK3EY+AlWJU+MaWss2 xgdW94zPEfRMuzBwBJWl9jmM/XOBCH2JXjIeIqkiRUuwZi4wzJ9l/fzLganx4Duvo4bRierERXlQ Xa7pIXSSTYtZgo+U4+lK8edJsBTj9WLL1XK9H7nSn6DNqPoByNkN39r8R52zyFTfSUrxIan+GE7u SNQZu+995OKdy1u2bv/jzVrndIIFuoAlOMvkaZ6vQaoahPUCAwEAAaOCATQwggEwMA8GA1UdEwEB /wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTjq1RMgKHbVkO3kUrL84J6E1wIqzCB 7QYDVR0fBIHlMIHiMIHfoIHcoIHZhjVodHRwOi8vd3d3LnRydXN0Y2VudGVyLmRlL2NybC92Mi90 Y19jbGFzc18yX2NhX0lJLmNybIaBn2xkYXA6Ly93d3cudHJ1c3RjZW50ZXIuZGUvQ049VEMlMjBU cnVzdENlbnRlciUyMENsYXNzJTIwMiUyMENBJTIwSUksTz1UQyUyMFRydXN0Q2VudGVyJTIwR21i SCxPVT1yb290Y2VydHMsREM9dHJ1c3RjZW50ZXIsREM9ZGU/Y2VydGlmaWNhdGVSZXZvY2F0aW9u TGlzdD9iYXNlPzANBgkqhkiG9w0BAQUFAAOCAQEAjNfffu4bgBCzg/XbEeprS6iSGNn3Bzn1LL4G dXpoUxUc6krtXvwjshOg0wn/9vYua0Fxec3ibf2uWWuFHbhOIprtZjluS5TmVfwLG4t3wVMTZonZ KNaL80VKY7f9ewthXbhtvsPcW3nS7Yblok2+XnR8au0WOB9/WIFaGusyiC2y8zl3gK9etmF1Kdsj TYjKUCjLhdLTEKJZbtOTVAB6okaVhgWcqRmY5TFyDADiZ9lA4CQze28suVyrZZ0srHbqNZn1l7kP JOzHdiEoZa5X6AeIdUpWoNIFOqTmjZKILPPy4cHGYdtBxceb9w4aUUXCYWvcZCcXjFq32nQozZfk vQ== -----END CERTIFICATE----- TC TrustCenter Class 3 CA II ============================ -----BEGIN CERTIFICATE----- MIIEqjCCA5KgAwIBAgIOSkcAAQAC5aBd1j8AUb8wDQYJKoZIhvcNAQEFBQAwdjELMAkGA1UEBhMC REUxHDAaBgNVBAoTE1RDIFRydXN0Q2VudGVyIEdtYkgxIjAgBgNVBAsTGVRDIFRydXN0Q2VudGVy IENsYXNzIDMgQ0ExJTAjBgNVBAMTHFRDIFRydXN0Q2VudGVyIENsYXNzIDMgQ0EgSUkwHhcNMDYw MTEyMTQ0MTU3WhcNMjUxMjMxMjI1OTU5WjB2MQswCQYDVQQGEwJERTEcMBoGA1UEChMTVEMgVHJ1 c3RDZW50ZXIgR21iSDEiMCAGA1UECxMZVEMgVHJ1c3RDZW50ZXIgQ2xhc3MgMyBDQTElMCMGA1UE AxMcVEMgVHJ1c3RDZW50ZXIgQ2xhc3MgMyBDQSBJSTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC AQoCggEBALTgu1G7OVyLBMVMeRwjhjEQY0NVJz/GRcekPewJDRoeIMJWHt4bNwcwIi9v8Qbxq63W yKthoy9DxLCyLfzDlml7forkzMA5EpBCYMnMNWju2l+QVl/NHE1bWEnrDgFPZPosPIlY2C8u4rBo 6SI7dYnWRBpl8huXJh0obazovVkdKyT21oQDZogkAHhg8fir/gKya/si+zXmFtGt9i4S5Po1auUZ uV3bOx4a+9P/FRQI2AlqukWdFHlgfa9Aigdzs5OW03Q0jTo3Kd5c7PXuLjHCINy+8U9/I1LZW+Jk 2ZyqBwi1Rb3R0DHBq1SfqdLDYmAD8bs5SpJKPQq5ncWg/jcCAwEAAaOCATQwggEwMA8GA1UdEwEB /wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTUovyfs8PYA9NXXAek0CSnwPIA1DCB 7QYDVR0fBIHlMIHiMIHfoIHcoIHZhjVodHRwOi8vd3d3LnRydXN0Y2VudGVyLmRlL2NybC92Mi90 Y19jbGFzc18zX2NhX0lJLmNybIaBn2xkYXA6Ly93d3cudHJ1c3RjZW50ZXIuZGUvQ049VEMlMjBU cnVzdENlbnRlciUyMENsYXNzJTIwMyUyMENBJTIwSUksTz1UQyUyMFRydXN0Q2VudGVyJTIwR21i SCxPVT1yb290Y2VydHMsREM9dHJ1c3RjZW50ZXIsREM9ZGU/Y2VydGlmaWNhdGVSZXZvY2F0aW9u TGlzdD9iYXNlPzANBgkqhkiG9w0BAQUFAAOCAQEANmDkcPcGIEPZIxpC8vijsrlNirTzwppVMXzE O2eatN9NDoqTSheLG43KieHPOh6sHfGcMrSOWXaiQYUlN6AT0PV8TtXqluJucsG7Kv5sbviRmEb8 yRtXW+rIGjs/sFGYPAfaLFkB2otE6OF0/ado3VS6g0bsyEa1+K+XwDsJHI/OcpY9M1ZwvJbL2NV9 IJqDnxrcOfHFcqMRA/07QlIp2+gB95tejNaNhk4Z+rwcvsUhpYeeeC422wlxo3I0+GzjBgnyXlal 092Y+tTmBvTwtiBjS+opvaqCZh77gaqnN60TGOaSw4HBM7uIHqHn4rS9MWwOUT1v+5ZWgOI2F9Hc 5A== -----END CERTIFICATE----- TC TrustCenter Universal CA I ============================= -----BEGIN CERTIFICATE----- MIID3TCCAsWgAwIBAgIOHaIAAQAC7LdggHiNtgYwDQYJKoZIhvcNAQEFBQAweTELMAkGA1UEBhMC REUxHDAaBgNVBAoTE1RDIFRydXN0Q2VudGVyIEdtYkgxJDAiBgNVBAsTG1RDIFRydXN0Q2VudGVy IFVuaXZlcnNhbCBDQTEmMCQGA1UEAxMdVEMgVHJ1c3RDZW50ZXIgVW5pdmVyc2FsIENBIEkwHhcN MDYwMzIyMTU1NDI4WhcNMjUxMjMxMjI1OTU5WjB5MQswCQYDVQQGEwJERTEcMBoGA1UEChMTVEMg VHJ1c3RDZW50ZXIgR21iSDEkMCIGA1UECxMbVEMgVHJ1c3RDZW50ZXIgVW5pdmVyc2FsIENBMSYw JAYDVQQDEx1UQyBUcnVzdENlbnRlciBVbml2ZXJzYWwgQ0EgSTCCASIwDQYJKoZIhvcNAQEBBQAD ggEPADCCAQoCggEBAKR3I5ZEr5D0MacQ9CaHnPM42Q9e3s9B6DGtxnSRJJZ4Hgmgm5qVSkr1YnwC qMqs+1oEdjneX/H5s7/zA1hV0qq34wQi0fiU2iIIAI3TfCZdzHd55yx4Oagmcw6iXSVphU9VDprv xrlE4Vc93x9UIuVvZaozhDrzznq+VZeujRIPFDPiUHDDSYcTvFHe15gSWu86gzOSBnWLknwSaHtw ag+1m7Z3W0hZneTvWq3zwZ7U10VOylY0Ibw+F1tvdwxIAUMpsN0/lm7mlaoMwCC2/T42J5zjXM9O gdwZu5GQfezmlwQek8wiSdeXhrYTCjxDI3d+8NzmzSQfO4ObNDqDNOMCAwEAAaNjMGEwHwYDVR0j BBgwFoAUkqR1LKSevoFE63n8isWVpesQdXMwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC AYYwHQYDVR0OBBYEFJKkdSyknr6BROt5/IrFlaXrEHVzMA0GCSqGSIb3DQEBBQUAA4IBAQAo0uCG 1eb4e/CX3CJrO5UUVg8RMKWaTzqwOuAGy2X17caXJ/4l8lfmXpWMPmRgFVp/Lw0BxbFg/UU1z/Cy vwbZ71q+s2IhtNerNXxTPqYn8aEt2hojnczd7Dwtnic0XQ/CNnm8yUpiLe1r2X1BQ3y2qsrtYbE3 ghUJGooWMNjsydZHcnhLEEYUjl8Or+zHL6sQ17bxbuyGssLoDZJz3KL0Dzq/YSMQiZxIQG5wALPT ujdEWBF6AmqI8Dc08BnprNRlc/ZpjGSUOnmFKbAWKwyCPwacx/0QK54PLLae4xW/2TYcuiUaUj0a 7CIMHOCkoj3w6DnPgcB77V0fb8XQC9eY -----END CERTIFICATE----- Deutsche Telekom Root CA 2 ========================== -----BEGIN CERTIFICATE----- MIIDnzCCAoegAwIBAgIBJjANBgkqhkiG9w0BAQUFADBxMQswCQYDVQQGEwJERTEcMBoGA1UEChMT RGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0GA1UECxMWVC1UZWxlU2VjIFRydXN0IENlbnRlcjEjMCEG A1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBSb290IENBIDIwHhcNOTkwNzA5MTIxMTAwWhcNMTkwNzA5 MjM1OTAwWjBxMQswCQYDVQQGEwJERTEcMBoGA1UEChMTRGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0G A1UECxMWVC1UZWxlU2VjIFRydXN0IENlbnRlcjEjMCEGA1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBS b290IENBIDIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCrC6M14IspFLEUha88EOQ5 bzVdSq7d6mGNlUn0b2SjGmBmpKlAIoTZ1KXleJMOaAGtuU1cOs7TuKhCQN/Po7qCWWqSG6wcmtoI KyUn+WkjR/Hg6yx6m/UTAtB+NHzCnjwAWav12gz1MjwrrFDa1sPeg5TKqAyZMg4ISFZbavva4VhY AUlfckE8FQYBjl2tqriTtM2e66foai1SNNs671x1Udrb8zH57nGYMsRUFUQM+ZtV7a3fGAigo4aK Se5TBY8ZTNXeWHmb0mocQqvF1afPaA+W5OFhmHZhyJF81j4A4pFQh+GdCuatl9Idxjp9y7zaAzTV jlsB9WoHtxa2bkp/AgMBAAGjQjBAMB0GA1UdDgQWBBQxw3kbuvVT1xfgiXotF2wKsyudMzAPBgNV HRMECDAGAQH/AgEFMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAlGRZrTlk5ynr E/5aw4sTV8gEJPB0d8Bg42f76Ymmg7+Wgnxu1MM9756AbrsptJh6sTtU6zkXR34ajgv8HzFZMQSy zhfzLMdiNlXiItiJVbSYSKpk+tYcNthEeFpaIzpXl/V6ME+un2pMSyuOoAPjPuCp1NJ70rOo4nI8 rZ7/gFnkm0W09juwzTkZmDLl6iFhkOQxIY40sfcvNUqFENrnijchvllj4PKFiDFT1FQUhXB59C4G dyd1Lx+4ivn+xbrYNuSD7Odlt79jWvNGr4GUN9RBjNYj1h7P9WgbRGOiWrqnNVmh5XAFmw4jV5mU Cm26OWMohpLzGITY+9HPBVZkVw== -----END CERTIFICATE----- ComSign Secured CA ================== -----BEGIN CERTIFICATE----- MIIDqzCCApOgAwIBAgIRAMcoRwmzuGxFjB36JPU2TukwDQYJKoZIhvcNAQEFBQAwPDEbMBkGA1UE AxMSQ29tU2lnbiBTZWN1cmVkIENBMRAwDgYDVQQKEwdDb21TaWduMQswCQYDVQQGEwJJTDAeFw0w NDAzMjQxMTM3MjBaFw0yOTAzMTYxNTA0NTZaMDwxGzAZBgNVBAMTEkNvbVNpZ24gU2VjdXJlZCBD QTEQMA4GA1UEChMHQ29tU2lnbjELMAkGA1UEBhMCSUwwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAw ggEKAoIBAQDGtWhfHZQVw6QIVS3joFd67+l0Kru5fFdJGhFeTymHDEjWaueP1H5XJLkGieQcPOqs 49ohgHMhCu95mGwfCP+hUH3ymBvJVG8+pSjsIQQPRbsHPaHA+iqYHU4Gk/v1iDurX8sWv+bznkqH 7Rnqwp9D5PGBpX8QTz7RSmKtUxvLg/8HZaWSLWapW7ha9B20IZFKF3ueMv5WJDmyVIRD9YTC2LxB kMyd1mja6YJQqTtoz7VdApRgFrFD2UNd3V2Hbuq7s8lr9gOUCXDeFhF6K+h2j0kQmHe5Y1yLM5d1 9guMsqtb3nQgJT/j8xH5h2iGNXHDHYwt6+UarA9z1YJZQIDTAgMBAAGjgacwgaQwDAYDVR0TBAUw AwEB/zBEBgNVHR8EPTA7MDmgN6A1hjNodHRwOi8vZmVkaXIuY29tc2lnbi5jby5pbC9jcmwvQ29t U2lnblNlY3VyZWRDQS5jcmwwDgYDVR0PAQH/BAQDAgGGMB8GA1UdIwQYMBaAFMFL7XC29z58ADsA j8c+DkWfHl3sMB0GA1UdDgQWBBTBS+1wtvc+fAA7AI/HPg5Fnx5d7DANBgkqhkiG9w0BAQUFAAOC AQEAFs/ukhNQq3sUnjO2QiBq1BW9Cav8cujvR3qQrFHBZE7piL1DRYHjZiM/EoZNGeQFsOY3wo3a BijJD4mkU6l1P7CW+6tMM1X5eCZGbxs2mPtCdsGCuY7e+0X5YxtiOzkGynd6qDwJz2w2PQ8KRUtp FhpFfTMDZflScZAmlaxMDPWLkz/MdXSFmLr/YnpNH4n+rr2UAJm/EaXc4HnFFgt9AmEd6oX5AhVP 51qJThRv4zdLhfXBPGHg/QVBspJ/wx2g0K5SZGBrGMYmnNj1ZOQ2GmKfig8+/21OGVZOIJFsnzQz OjRXUDpvgV4GxvU+fE6OK85lBi5d0ipTdF7Tbieejw== -----END CERTIFICATE----- Cybertrust Global Root ====================== -----BEGIN CERTIFICATE----- MIIDoTCCAomgAwIBAgILBAAAAAABD4WqLUgwDQYJKoZIhvcNAQEFBQAwOzEYMBYGA1UEChMPQ3li ZXJ0cnVzdCwgSW5jMR8wHQYDVQQDExZDeWJlcnRydXN0IEdsb2JhbCBSb290MB4XDTA2MTIxNTA4 MDAwMFoXDTIxMTIxNTA4MDAwMFowOzEYMBYGA1UEChMPQ3liZXJ0cnVzdCwgSW5jMR8wHQYDVQQD ExZDeWJlcnRydXN0IEdsb2JhbCBSb290MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA +Mi8vRRQZhP/8NN57CPytxrHjoXxEnOmGaoQ25yiZXRadz5RfVb23CO21O1fWLE3TdVJDm71aofW 0ozSJ8bi/zafmGWgE07GKmSb1ZASzxQG9Dvj1Ci+6A74q05IlG2OlTEQXO2iLb3VOm2yHLtgwEZL AfVJrn5GitB0jaEMAs7u/OePuGtm839EAL9mJRQr3RAwHQeWP032a7iPt3sMpTjr3kfb1V05/Iin 89cqdPHoWqI7n1C6poxFNcJQZZXcY4Lv3b93TZxiyWNzFtApD0mpSPCzqrdsxacwOUBdrsTiXSZT 8M4cIwhhqJQZugRiQOwfOHB3EgZxpzAYXSUnpQIDAQABo4GlMIGiMA4GA1UdDwEB/wQEAwIBBjAP BgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBS2CHsNesysIEyGVjJez6tuhS1wVzA/BgNVHR8EODA2 MDSgMqAwhi5odHRwOi8vd3d3Mi5wdWJsaWMtdHJ1c3QuY29tL2NybC9jdC9jdHJvb3QuY3JsMB8G A1UdIwQYMBaAFLYIew16zKwgTIZWMl7Pq26FLXBXMA0GCSqGSIb3DQEBBQUAA4IBAQBW7wojoFRO lZfJ+InaRcHUowAl9B8Tq7ejhVhpwjCt2BWKLePJzYFa+HMjWqd8BfP9IjsO0QbE2zZMcwSO5bAi 5MXzLqXZI+O4Tkogp24CJJ8iYGd7ix1yCcUxXOl5n4BHPa2hCwcUPUf/A2kaDAtE52Mlp3+yybh2 hO0j9n0Hq0V+09+zv+mKts2oomcrUtW3ZfA5TGOgkXmTUg9U3YO7n9GPp1Nzw8v/MOx8BLjYRB+T X3EJIrduPuocA06dGiBh+4E37F78CkWr1+cXVdCg6mCbpvbjjFspwgZgFJ0tl0ypkxWdYcQBX0jW WL1WMRJOEcgh4LMRkWXbtKaIOM5V -----END CERTIFICATE----- ePKI Root Certification Authority ================================= -----BEGIN CERTIFICATE----- MIIFsDCCA5igAwIBAgIQFci9ZUdcr7iXAF7kBtK8nTANBgkqhkiG9w0BAQUFADBeMQswCQYDVQQG EwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0ZC4xKjAoBgNVBAsMIWVQS0kg Um9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNDEyMjAwMjMxMjdaFw0zNDEyMjAwMjMx MjdaMF4xCzAJBgNVBAYTAlRXMSMwIQYDVQQKDBpDaHVuZ2h3YSBUZWxlY29tIENvLiwgTHRkLjEq MCgGA1UECwwhZVBLSSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIICIjANBgkqhkiG9w0B AQEFAAOCAg8AMIICCgKCAgEA4SUP7o3biDN1Z82tH306Tm2d0y8U82N0ywEhajfqhFAHSyZbCUNs IZ5qyNUD9WBpj8zwIuQf5/dqIjG3LBXy4P4AakP/h2XGtRrBp0xtInAhijHyl3SJCRImHJ7K2RKi lTza6We/CKBk49ZCt0Xvl/T29de1ShUCWH2YWEtgvM3XDZoTM1PRYfl61dd4s5oz9wCGzh1NlDiv qOx4UXCKXBCDUSH3ET00hl7lSM2XgYI1TBnsZfZrxQWh7kcT1rMhJ5QQCtkkO7q+RBNGMD+XPNjX 12ruOzjjK9SXDrkb5wdJfzcq+Xd4z1TtW0ado4AOkUPB1ltfFLqfpo0kR0BZv3I4sjZsN/+Z0V0O WQqraffAsgRFelQArr5T9rXn4fg8ozHSqf4hUmTFpmfwdQcGlBSBVcYn5AGPF8Fqcde+S/uUWH1+ ETOxQvdibBjWzwloPn9s9h6PYq2lY9sJpx8iQkEeb5mKPtf5P0B6ebClAZLSnT0IFaUQAS2zMnao lQ2zepr7BxB4EW/hj8e6DyUadCrlHJhBmd8hh+iVBmoKs2pHdmX2Os+PYhcZewoozRrSgx4hxyy/ vv9haLdnG7t4TY3OZ+XkwY63I2binZB1NJipNiuKmpS5nezMirH4JYlcWrYvjB9teSSnUmjDhDXi Zo1jDiVN1Rmy5nk3pyKdVDECAwEAAaNqMGgwHQYDVR0OBBYEFB4M97Zn8uGSJglFwFU5Lnc/Qkqi MAwGA1UdEwQFMAMBAf8wOQYEZyoHAAQxMC8wLQIBADAJBgUrDgMCGgUAMAcGBWcqAwAABBRFsMLH ClZ87lt4DJX5GFPBphzYEDANBgkqhkiG9w0BAQUFAAOCAgEACbODU1kBPpVJufGBuvl2ICO1J2B0 1GqZNF5sAFPZn/KmsSQHRGoqxqWOeBLoR9lYGxMqXnmbnwoqZ6YlPwZpVnPDimZI+ymBV3QGypzq KOg4ZyYr8dW1P2WT+DZdjo2NQCCHGervJ8A9tDkPJXtoUHRVnAxZfVo9QZQlUgjgRywVMRnVvwdV xrsStZf0X4OFunHB2WyBEXYKCrC/gpf36j36+uwtqSiUO1bd0lEursC9CBWMd1I0ltabrNMdjmEP NXubrjlpC2JgQCA2j6/7Nu4tCEoduL+bXPjqpRugc6bY+G7gMwRfaKonh+3ZwZCc7b3jajWvY9+r GNm65ulK6lCKD2GTHuItGeIwlDWSXQ62B68ZgI9HkFFLLk3dheLSClIKF5r8GrBQAuUBo2M3IUxE xJtRmREOc5wGj1QupyheRDmHVi03vYVElOEMSyycw5KFNGHLD7ibSkNS/jQ6fbjpKdx2qcgw+BRx gMYeNkh0IkFch4LoGHGLQYlE535YW6i4jRPpp2zDR+2zGp1iro2C6pSe3VkQw63d4k3jMdXH7Ojy sP6SHhYKGvzZ8/gntsm+HbRsZJB/9OTEW9c3rkIO3aQab3yIVMUWbuF6aC74Or8NpDyJO3inTmOD BCEIZ43ygknQW/2xzQ+DhNQ+IIX3Sj0rnP0qCglN6oH4EZw= -----END CERTIFICATE----- T\xc3\x9c\x42\xC4\xB0TAK UEKAE K\xC3\xB6k Sertifika Hizmet Sa\xC4\x9Flay\xc4\xb1\x63\xc4\xb1s\xc4\xb1 - S\xC3\xBCr\xC3\xBCm 3 ============================================================================================================================= -----BEGIN CERTIFICATE----- MIIFFzCCA/+gAwIBAgIBETANBgkqhkiG9w0BAQUFADCCASsxCzAJBgNVBAYTAlRSMRgwFgYDVQQH DA9HZWJ6ZSAtIEtvY2FlbGkxRzBFBgNVBAoMPlTDvHJraXllIEJpbGltc2VsIHZlIFRla25vbG9q aWsgQXJhxZ90xLFybWEgS3VydW11IC0gVMOcQsSwVEFLMUgwRgYDVQQLDD9VbHVzYWwgRWxla3Ry b25payB2ZSBLcmlwdG9sb2ppIEFyYcWfdMSxcm1hIEVuc3RpdMO8c8O8IC0gVUVLQUUxIzAhBgNV BAsMGkthbXUgU2VydGlmaWthc3lvbiBNZXJrZXppMUowSAYDVQQDDEFUw5xCxLBUQUsgVUVLQUUg S8O2ayBTZXJ0aWZpa2EgSGl6bWV0IFNhxJ9sYXnEsWPEsXPEsSAtIFPDvHLDvG0gMzAeFw0wNzA4 MjQxMTM3MDdaFw0xNzA4MjExMTM3MDdaMIIBKzELMAkGA1UEBhMCVFIxGDAWBgNVBAcMD0dlYnpl IC0gS29jYWVsaTFHMEUGA1UECgw+VMO8cmtpeWUgQmlsaW1zZWwgdmUgVGVrbm9sb2ppayBBcmHF n3TEsXJtYSBLdXJ1bXUgLSBUw5xCxLBUQUsxSDBGBgNVBAsMP1VsdXNhbCBFbGVrdHJvbmlrIHZl IEtyaXB0b2xvamkgQXJhxZ90xLFybWEgRW5zdGl0w7xzw7wgLSBVRUtBRTEjMCEGA1UECwwaS2Ft dSBTZXJ0aWZpa2FzeW9uIE1lcmtlemkxSjBIBgNVBAMMQVTDnELEsFRBSyBVRUtBRSBLw7ZrIFNl cnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxIC0gU8O8csO8bSAzMIIBIjANBgkqhkiG9w0B AQEFAAOCAQ8AMIIBCgKCAQEAim1L/xCIOsP2fpTo6iBkcK4hgb46ezzb8R1Sf1n68yJMlaCQvEhO Eav7t7WNeoMojCZG2E6VQIdhn8WebYGHV2yKO7Rm6sxA/OOqbLLLAdsyv9Lrhc+hDVXDWzhXcLh1 xnnRFDDtG1hba+818qEhTsXOfJlfbLm4IpNQp81McGq+agV/E5wrHur+R84EpW+sky58K5+eeROR 6Oqeyjh1jmKwlZMq5d/pXpduIF9fhHpEORlAHLpVK/swsoHvhOPc7Jg4OQOFCKlUAwUp8MmPi+oL hmUZEdPpCSPeaJMDyTYcIW7OjGbxmTDY17PDHfiBLqi9ggtm/oLL4eAagsNAgQIDAQABo0IwQDAd BgNVHQ4EFgQUvYiHyY/2pAoLquvF/pEjnatKijIwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQF MAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAB18+kmPNOm3JpIWmgV050vQbTlswyb2zrgxvMTfvCr4 N5EY3ATIZJkrGG2AA1nJrvhY0D7twyOfaTyGOBye79oneNGEN3GKPEs5z35FBtYt2IpNeBLWrcLT y9LQQfMmNkqblWwM7uXRQydmwYj3erMgbOqwaSvHIOgMA8RBBZniP+Rr+KCGgceExh/VS4ESshYh LBOhgLJeDEoTniDYYkCrkOpkSi+sDQESeUWoL4cZaMjihccwsnX5OD+ywJO0a+IDRM5noN+J1q2M dqMTw5RhK2vZbMEHCiIHhWyFJEapvj+LeISCfiQMnf2BN+MlqO02TpUsyZyQ2uypQjyttgI= -----END CERTIFICATE----- Buypass Class 2 CA 1 ==================== -----BEGIN CERTIFICATE----- MIIDUzCCAjugAwIBAgIBATANBgkqhkiG9w0BAQUFADBLMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU QnV5cGFzcyBBUy05ODMxNjMzMjcxHTAbBgNVBAMMFEJ1eXBhc3MgQ2xhc3MgMiBDQSAxMB4XDTA2 MTAxMzEwMjUwOVoXDTE2MTAxMzEwMjUwOVowSzELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBh c3MgQVMtOTgzMTYzMzI3MR0wGwYDVQQDDBRCdXlwYXNzIENsYXNzIDIgQ0EgMTCCASIwDQYJKoZI hvcNAQEBBQADggEPADCCAQoCggEBAIs8B0XY9t/mx8q6jUPFR42wWsE425KEHK8T1A9vNkYgxC7M cXA0ojTTNy7Y3Tp3L8DrKehc0rWpkTSHIln+zNvnma+WwajHQN2lFYxuyHyXA8vmIPLXl18xoS83 0r7uvqmtqEyeIWZDO6i88wmjONVZJMHCR3axiFyCO7srpgTXjAePzdVBHfCuuCkslFJgNJQ72uA4 0Z0zPhX0kzLFANq1KWYOOngPIVJfAuWSeyXTkh4vFZ2B5J2O6O+JzhRMVB0cgRJNcKi+EAUXfh/R uFdV7c27UsKwHnjCTTZoy1YmwVLBvXb3WNVyfh9EdrsAiR0WnVE1703CVu9r4Iw7DekCAwEAAaNC MEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUP42aWYv8e3uco684sDntkHGA1sgwDgYDVR0P AQH/BAQDAgEGMA0GCSqGSIb3DQEBBQUAA4IBAQAVGn4TirnoB6NLJzKyQJHyIdFkhb5jatLPgcIV 1Xp+DCmsNx4cfHZSldq1fyOhKXdlyTKdqC5Wq2B2zha0jX94wNWZUYN/Xtm+DKhQ7SLHrQVMdvvt 7h5HZPb3J31cKA9FxVxiXqaakZG3Uxcu3K1gnZZkOb1naLKuBctN518fV4bVIJwo+28TOPX2EZL2 fZleHwzoq0QkKXJAPTZSr4xYkHPB7GEseaHsh7U/2k3ZIQAw3pDaDtMaSKk+hQsUi4y8QZ5q9w5w wDX3OaJdZtB7WZ+oRxKaJyOkLY4ng5IgodcVf/EuGO70SH8vf/GhGLWhC5SgYiAynB321O+/TIho -----END CERTIFICATE----- Buypass Class 3 CA 1 ==================== -----BEGIN CERTIFICATE----- MIIDUzCCAjugAwIBAgIBAjANBgkqhkiG9w0BAQUFADBLMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU QnV5cGFzcyBBUy05ODMxNjMzMjcxHTAbBgNVBAMMFEJ1eXBhc3MgQ2xhc3MgMyBDQSAxMB4XDTA1 MDUwOTE0MTMwM1oXDTE1MDUwOTE0MTMwM1owSzELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBh c3MgQVMtOTgzMTYzMzI3MR0wGwYDVQQDDBRCdXlwYXNzIENsYXNzIDMgQ0EgMTCCASIwDQYJKoZI hvcNAQEBBQADggEPADCCAQoCggEBAKSO13TZKWTeXx+HgJHqTjnmGcZEC4DVC69TB4sSveZn8AKx ifZgisRbsELRwCGoy+Gb72RRtqfPFfV0gGgEkKBYouZ0plNTVUhjP5JW3SROjvi6K//zNIqeKNc0 n6wv1g/xpC+9UrJJhW05NfBEMJNGJPO251P7vGGvqaMU+8IXF4Rs4HyI+MkcVyzwPX6UvCWThOia AJpFBUJXgPROztmuOfbIUxAMZTpHe2DC1vqRycZxbL2RhzyRhkmr8w+gbCZ2Xhysm3HljbybIR6c 1jh+JIAVMYKWsUnTYjdbiAwKYjT+p0h+mbEwi5A3lRyoH6UsjfRVyNvdWQrCrXig9IsCAwEAAaNC MEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUOBTmyPCppAP0Tj4io1vy1uCtQHQwDgYDVR0P AQH/BAQDAgEGMA0GCSqGSIb3DQEBBQUAA4IBAQABZ6OMySU9E2NdFm/soT4JXJEVKirZgCFPBdy7 pYmrEzMqnji3jG8CcmPHc3ceCQa6Oyh7pEfJYWsICCD8igWKH7y6xsL+z27sEzNxZy5p+qksP2bA EllNC1QCkoS72xLvg3BweMhT+t/Gxv/ciC8HwEmdMldg0/L2mSlf56oBzKwzqBwKu5HEA6BvtjT5 htOzdlSY9EqBs1OdTUDs5XcTRa9bqh/YL0yCe/4qxFi7T/ye/QNlGioOw6UgFpRreaaiErS7GqQj el/wroQk5PMr+4okoyeYZdowdXb8GZHo2+ubPzK/QJcHJrrM85SFSnonk8+QQtS4Wxam58tAA915 -----END CERTIFICATE----- EBG Elektronik Sertifika Hizmet Sa\xC4\x9Flay\xc4\xb1\x63\xc4\xb1s\xc4\xb1 ========================================================================== -----BEGIN CERTIFICATE----- MIIF5zCCA8+gAwIBAgIITK9zQhyOdAIwDQYJKoZIhvcNAQEFBQAwgYAxODA2BgNVBAMML0VCRyBF bGVrdHJvbmlrIFNlcnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxMTcwNQYDVQQKDC5FQkcg QmlsacWfaW0gVGVrbm9sb2ppbGVyaSB2ZSBIaXptZXRsZXJpIEEuxZ4uMQswCQYDVQQGEwJUUjAe Fw0wNjA4MTcwMDIxMDlaFw0xNjA4MTQwMDMxMDlaMIGAMTgwNgYDVQQDDC9FQkcgRWxla3Ryb25p ayBTZXJ0aWZpa2EgSGl6bWV0IFNhxJ9sYXnEsWPEsXPEsTE3MDUGA1UECgwuRUJHIEJpbGnFn2lt IFRla25vbG9qaWxlcmkgdmUgSGl6bWV0bGVyaSBBLsWeLjELMAkGA1UEBhMCVFIwggIiMA0GCSqG SIb3DQEBAQUAA4ICDwAwggIKAoICAQDuoIRh0DpqZhAy2DE4f6en5f2h4fuXd7hxlugTlkaDT7by X3JWbhNgpQGR4lvFzVcfd2NR/y8927k/qqk153nQ9dAktiHq6yOU/im/+4mRDGSaBUorzAzu8T2b gmmkTPiab+ci2hC6X5L8GCcKqKpE+i4stPtGmggDg3KriORqcsnlZR9uKg+ds+g75AxuetpX/dfr eYteIAbTdgtsApWjluTLdlHRKJ2hGvxEok3MenaoDT2/F08iiFD9rrbskFBKW5+VQarKD7JK/oCZ TqNGFav4c0JqwmZ2sQomFd2TkuzbqV9UIlKRcF0T6kjsbgNs2d1s/OsNA/+mgxKb8amTD8UmTDGy Y5lhcucqZJnSuOl14nypqZoaqsNW2xCaPINStnuWt6yHd6i58mcLlEOzrz5z+kI2sSXFCjEmN1Zn uqMLfdb3ic1nobc6HmZP9qBVFCVMLDMNpkGMvQQxahByCp0OLna9XvNRiYuoP1Vzv9s6xiQFlpJI qkuNKgPlV5EQ9GooFW5Hd4RcUXSfGenmHmMWOeMRFeNYGkS9y8RsZteEBt8w9DeiQyJ50hBs37vm ExH8nYQKE3vwO9D8owrXieqWfo1IhR5kX9tUoqzVegJ5a9KK8GfaZXINFHDk6Y54jzJ0fFfy1tb0 Nokb+Clsi7n2l9GkLqq+CxnCRelwXQIDAJ3Zo2MwYTAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB /wQEAwIBBjAdBgNVHQ4EFgQU587GT/wWZ5b6SqMHwQSny2re2kcwHwYDVR0jBBgwFoAU587GT/wW Z5b6SqMHwQSny2re2kcwDQYJKoZIhvcNAQEFBQADggIBAJuYml2+8ygjdsZs93/mQJ7ANtyVDR2t FcU22NU57/IeIl6zgrRdu0waypIN30ckHrMk2pGI6YNw3ZPX6bqz3xZaPt7gyPvT/Wwp+BVGoGgm zJNSroIBk5DKd8pNSe/iWtkqvTDOTLKBtjDOWU/aWR1qeqRFsIImgYZ29fUQALjuswnoT4cCB64k XPBfrAowzIpAoHMEwfuJJPaaHFy3PApnNgUIMbOv2AFoKuB4j3TeuFGkjGwgPaL7s9QJ/XvCgKqT bCmYIai7FvOpEl90tYeY8pUm3zTvilORiF0alKM/fCL414i6poyWqD1SNGKfAB5UVUJnxk1Gj7sU RT0KlhaOEKGXmdXTMIXM3rRyt7yKPBgpaP3ccQfuJDlq+u2lrDgv+R4QDgZxGhBM/nV+/x5XOULK 1+EVoVZVWRvRo68R2E7DpSvvkL/A7IITW43WciyTTo9qKd+FPNMN4KIYEsxVL0e3p5sC/kH2iExt 2qkBR4NkJ2IQgtYSe14DHzSpyZH+r11thie3I6p1GMog57AP14kOpmciY/SDQSsGS7tY1dHXt7kQ Y9iJSrSq3RZj9W6+YKH47ejWkE8axsWgKdOnIaj1Wjz3x0miIZpKlVIglnKaZsv30oZDfCK+lvm9 AahH3eU7QPl1K5srRmSGjR70j/sHd9DqSaIcjVIUpgqT -----END CERTIFICATE----- certSIGN ROOT CA ================ -----BEGIN CERTIFICATE----- MIIDODCCAiCgAwIBAgIGIAYFFnACMA0GCSqGSIb3DQEBBQUAMDsxCzAJBgNVBAYTAlJPMREwDwYD VQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBDQTAeFw0wNjA3MDQxNzIwMDRa Fw0zMTA3MDQxNzIwMDRaMDsxCzAJBgNVBAYTAlJPMREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UE CxMQY2VydFNJR04gUk9PVCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALczuX7I JUqOtdu0KBuqV5Do0SLTZLrTk+jUrIZhQGpgV2hUhE28alQCBf/fm5oqrl0Hj0rDKH/v+yv6efHH rfAQUySQi2bJqIirr1qjAOm+ukbuW3N7LBeCgV5iLKECZbO9xSsAfsT8AzNXDe3i+s5dRdY4zTW2 ssHQnIFKquSyAVwdj1+ZxLGt24gh65AIgoDzMKND5pCCrlUoSe1b16kQOA7+j0xbm0bqQfWwCHTD 0IgztnzXdN/chNFDDnU5oSVAKOp4yw4sLjmdjItuFhwvJoIQ4uNllAoEwF73XVv4EOLQunpL+943 AAAaWyjj0pxzPjKHmKHJUS/X3qwzs08CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8B Af8EBAMCAcYwHQYDVR0OBBYEFOCMm9slSbPxfIbWskKHC9BroNnkMA0GCSqGSIb3DQEBBQUAA4IB AQA+0hyJLjX8+HXd5n9liPRyTMks1zJO890ZeUe9jjtbkw9QSSQTaxQGcu8J06Gh40CEyecYMnQ8 SG4Pn0vU9x7Tk4ZkVJdjclDVVc/6IJMCopvDI5NOFlV2oHB5bc0hH88vLbwZ44gx+FkagQnIl6Z0 x2DEW8xXjrJ1/RsCCdtZb3KTafcxQdaIOL+Hsr0Wefmq5L6IJd1hJyMctTEHBDa0GpC9oHRxUIlt vBTjD4au8as+x6AJzKNI0eDbZOeStc+vckNwi/nDhDwTqn6Sm1dTk/pwwpEOMfmbZ13pljheX7Nz TogVZ96edhBiIL5VaZVDADlN9u6wWk5JRFRYX0KD -----END CERTIFICATE----- CNNIC ROOT ========== -----BEGIN CERTIFICATE----- MIIDVTCCAj2gAwIBAgIESTMAATANBgkqhkiG9w0BAQUFADAyMQswCQYDVQQGEwJDTjEOMAwGA1UE ChMFQ05OSUMxEzARBgNVBAMTCkNOTklDIFJPT1QwHhcNMDcwNDE2MDcwOTE0WhcNMjcwNDE2MDcw OTE0WjAyMQswCQYDVQQGEwJDTjEOMAwGA1UEChMFQ05OSUMxEzARBgNVBAMTCkNOTklDIFJPT1Qw ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDTNfc/c3et6FtzF8LRb+1VvG7q6KR5smzD o+/hn7E7SIX1mlwhIhAsxYLO2uOabjfhhyzcuQxauohV3/2q2x8x6gHx3zkBwRP9SFIhxFXf2tiz VHa6dLG3fdfA6PZZxU3Iva0fFNrfWEQlMhkqx35+jq44sDB7R3IJMfAw28Mbdim7aXZOV/kbZKKT VrdvmW7bCgScEeOAH8tjlBAKqeFkgjH5jCftppkA9nCTGPihNIaj3XrCGHn2emU1z5DrvTOTn1Or czvmmzQgLx3vqR1jGqCA2wMv+SYahtKNu6m+UjqHZ0gNv7Sg2Ca+I19zN38m5pIEo3/PIKe38zrK y5nLAgMBAAGjczBxMBEGCWCGSAGG+EIBAQQEAwIABzAfBgNVHSMEGDAWgBRl8jGtKvf33VKWCscC wQ7vptU7ETAPBgNVHRMBAf8EBTADAQH/MAsGA1UdDwQEAwIB/jAdBgNVHQ4EFgQUZfIxrSr3991S lgrHAsEO76bVOxEwDQYJKoZIhvcNAQEFBQADggEBAEs17szkrr/Dbq2flTtLP1se31cpolnKOOK5 Gv+e5m4y3R6u6jW39ZORTtpC4cMXYFDy0VwmuYK36m3knITnA3kXr5g9lNvHugDnuL8BV8F3RTIM O/G0HAiw/VGgod2aHRM2mm23xzy54cXZF/qD1T0VoDy7HgviyJA/qIYM/PmLXoXLT1tLYhFHxUV8 BS9BsZ4QaRuZluBVeftOhpm4lNqGOGqTo+fLbuXf6iFViZx9fX+Y9QCJ7uOEwFyWtcVG6kbghVW2 G8kS1sHNzYDzAgE8yGnLRUhj2JTQ7IUOO04RZfSCjKY9ri4ilAnIXOo8gV0WKgOXFlUJ24pBgp5m mxE= -----END CERTIFICATE----- ApplicationCA - Japanese Government =================================== -----BEGIN CERTIFICATE----- MIIDoDCCAoigAwIBAgIBMTANBgkqhkiG9w0BAQUFADBDMQswCQYDVQQGEwJKUDEcMBoGA1UEChMT SmFwYW5lc2UgR292ZXJubWVudDEWMBQGA1UECxMNQXBwbGljYXRpb25DQTAeFw0wNzEyMTIxNTAw MDBaFw0xNzEyMTIxNTAwMDBaMEMxCzAJBgNVBAYTAkpQMRwwGgYDVQQKExNKYXBhbmVzZSBHb3Zl cm5tZW50MRYwFAYDVQQLEw1BcHBsaWNhdGlvbkNBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB CgKCAQEAp23gdE6Hj6UG3mii24aZS2QNcfAKBZuOquHMLtJqO8F6tJdhjYq+xpqcBrSGUeQ3DnR4 fl+Kf5Sk10cI/VBaVuRorChzoHvpfxiSQE8tnfWuREhzNgaeZCw7NCPbXCbkcXmP1G55IrmTwcrN wVbtiGrXoDkhBFcsovW8R0FPXjQilbUfKW1eSvNNcr5BViCH/OlQR9cwFO5cjFW6WY2H/CPek9AE jP3vbb3QesmlOmpyM8ZKDQUXKi17safY1vC+9D/qDihtQWEjdnjDuGWk81quzMKq2edY3rZ+nYVu nyoKb58DKTCXKB28t89UKU5RMfkntigm/qJj5kEW8DOYRwIDAQABo4GeMIGbMB0GA1UdDgQWBBRU WssmP3HMlEYNllPqa0jQk/5CdTAOBgNVHQ8BAf8EBAMCAQYwWQYDVR0RBFIwUKROMEwxCzAJBgNV BAYTAkpQMRgwFgYDVQQKDA/ml6XmnKzlm73mlL/lupwxIzAhBgNVBAsMGuOCouODl+ODquOCseOD vOOCt+ODp+ODs0NBMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBADlqRHZ3ODrs o2dGD/mLBqj7apAxzn7s2tGJfHrrLgy9mTLnsCTWw//1sogJhyzjVOGjprIIC8CFqMjSnHH2HZ9g /DgzE+Ge3Atf2hZQKXsvcJEPmbo0NI2VdMV+eKlmXb3KIXdCEKxmJj3ekav9FfBv7WxfEPjzFvYD io+nEhEMy/0/ecGc/WLuo89UDNErXxc+4z6/wCs+CZv+iKZ+tJIX/COUgb1up8WMwusRRdv4QcmW dupwX3kSa+SjB1oF7ydJzyGfikwJcGapJsErEU4z0g781mzSDjJkaP+tBXhfAx2o45CsJOAPQKdL rosot4LKGAfmt1t06SAZf7IbiVQ= -----END CERTIFICATE----- GeoTrust Primary Certification Authority - G3 ============================================= -----BEGIN CERTIFICATE----- MIID/jCCAuagAwIBAgIQFaxulBmyeUtB9iepwxgPHzANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UE BhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsTMChjKSAyMDA4IEdlb1RydXN0 IEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTE2MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFy eSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEczMB4XDTA4MDQwMjAwMDAwMFoXDTM3MTIwMTIz NTk1OVowgZgxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAo YykgMjAwOCBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0BgNVBAMT LUdlb1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBHMzCCASIwDQYJKoZI hvcNAQEBBQADggEPADCCAQoCggEBANziXmJYHTNXOTIz+uvLh4yn1ErdBojqZI4xmKU4kB6Yzy5j K/BGvESyiaHAKAxJcCGVn2TAppMSAmUmhsalifD614SgcK9PGpc/BkTVyetyEH3kMSj7HGHmKAdE c5IiaacDiGydY8hS2pgn5whMcD60yRLBxWeDXTPzAxHsatBT4tG6NmCUgLthY2xbF37fQJQeqw3C IShwiP/WJmxsYAQlTlV+fe+/lEjetx3dcI0FX4ilm/LC7urRQEFtYjgdVgbFA0dRIBn8exALDmKu dlW/X3e+PkkBUz2YJQN2JFodtNuJ6nnltrM7P7pMKEF/BqxqjsHQ9gUdfeZChuOl1UcCAwEAAaNC MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMR5yo6hTgMdHNxr 2zFblD4/MH8tMA0GCSqGSIb3DQEBCwUAA4IBAQAtxRPPVoB7eni9n64smefv2t+UXglpp+duaIy9 cr5HqQ6XErhK8WTTOd8lNNTBzU6B8A8ExCSzNJbGpqow32hhc9f5joWJ7w5elShKKiePEI4ufIbE Ap7aDHdlDkQNkv39sxY2+hENHYwOB4lqKVb3cvTdFZx3NWZXqxNT2I7BQMXXExZacse3aQHEerGD AWh9jUGhlBjBJVz88P6DAod8DQ3PLghcSkANPuyBYeYk28rgDi0Hsj5W3I31QYUHSJsMC8tJP33s t/3LjWeJGqvtux6jAAgIFyqCXDFdRootD4abdNlF+9RAsXqqaC2Gspki4cErx5z481+oghLrGREt -----END CERTIFICATE----- thawte Primary Root CA - G2 =========================== -----BEGIN CERTIFICATE----- MIICiDCCAg2gAwIBAgIQNfwmXNmET8k9Jj1Xm67XVjAKBggqhkjOPQQDAzCBhDELMAkGA1UEBhMC VVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjE4MDYGA1UECxMvKGMpIDIwMDcgdGhhd3RlLCBJbmMu IC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxJDAiBgNVBAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3Qg Q0EgLSBHMjAeFw0wNzExMDUwMDAwMDBaFw0zODAxMTgyMzU5NTlaMIGEMQswCQYDVQQGEwJVUzEV MBMGA1UEChMMdGhhd3RlLCBJbmMuMTgwNgYDVQQLEy8oYykgMjAwNyB0aGF3dGUsIEluYy4gLSBG b3IgYXV0aG9yaXplZCB1c2Ugb25seTEkMCIGA1UEAxMbdGhhd3RlIFByaW1hcnkgUm9vdCBDQSAt IEcyMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAEotWcgnuVnfFSeIf+iha/BebfowJPDQfGAFG6DAJS LSKkQjnE/o/qycG+1E3/n3qe4rF8mq2nhglzh9HnmuN6papu+7qzcMBniKI11KOasf2twu8x+qi5 8/sIxpHR+ymVo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQU mtgAMADna3+FGO6Lts6KDPgR4bswCgYIKoZIzj0EAwMDaQAwZgIxAN344FdHW6fmCsO99YCKlzUN G4k8VIZ3KMqh9HneteY4sPBlcIx/AlTCv//YoT7ZzwIxAMSNlPzcU9LcnXgWHxUzI1NS41oxXZ3K rr0TKUQNJ1uo52icEvdYPy5yAlejj6EULg== -----END CERTIFICATE----- thawte Primary Root CA - G3 =========================== -----BEGIN CERTIFICATE----- MIIEKjCCAxKgAwIBAgIQYAGXt0an6rS0mtZLL/eQ+zANBgkqhkiG9w0BAQsFADCBrjELMAkGA1UE BhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2 aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIwMDggdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhv cml6ZWQgdXNlIG9ubHkxJDAiBgNVBAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EgLSBHMzAeFw0w ODA0MDIwMDAwMDBaFw0zNzEyMDEyMzU5NTlaMIGuMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMdGhh d3RlLCBJbmMuMSgwJgYDVQQLEx9DZXJ0aWZpY2F0aW9uIFNlcnZpY2VzIERpdmlzaW9uMTgwNgYD VQQLEy8oYykgMjAwOCB0aGF3dGUsIEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTEkMCIG A1UEAxMbdGhhd3RlIFByaW1hcnkgUm9vdCBDQSAtIEczMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A MIIBCgKCAQEAsr8nLPvb2FvdeHsbnndmgcs+vHyu86YnmjSjaDFxODNi5PNxZnmxqWWjpYvVj2At P0LMqmsywCPLLEHd5N/8YZzic7IilRFDGF/Eth9XbAoFWCLINkw6fKXRz4aviKdEAhN0cXMKQlkC +BsUa0Lfb1+6a4KinVvnSr0eAXLbS3ToO39/fR8EtCab4LRarEc9VbjXsCZSKAExQGbY2SS99irY 7CFJXJv2eul/VTV+lmuNk5Mny5K76qxAwJ/C+IDPXfRa3M50hqY+bAtTyr2SzhkGcuYMXDhpxwTW vGzOW/b3aJzcJRVIiKHpqfiYnODz1TEoYRFsZ5aNOZnLwkUkOQIDAQABo0IwQDAPBgNVHRMBAf8E BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUrWyqlGCc7eT/+j4KdCtjA/e2Wb8wDQYJ KoZIhvcNAQELBQADggEBABpA2JVlrAmSicY59BDlqQ5mU1143vokkbvnRFHfxhY0Cu9qRFHqKweK A3rD6z8KLFIWoCtDuSWQP3CpMyVtRRooOyfPqsMpQhvfO0zAMzRbQYi/aytlryjvsvXDqmbOe1bu t8jLZ8HJnBoYuMTDSQPxYA5QzUbF83d597YV4Djbxy8ooAw/dyZ02SUS2jHaGh7cKUGRIjxpp7sC 8rZcJwOJ9Abqm+RyguOhCcHpABnTPtRwa7pxpqpYrvS76Wy274fMm7v/OeZWYdMKp8RcTGB7BXcm er/YB1IsYvdwY9k5vG8cwnncdimvzsUsZAReiDZuMdRAGmI0Nj81Aa6sY6A= -----END CERTIFICATE----- GeoTrust Primary Certification Authority - G2 ============================================= -----BEGIN CERTIFICATE----- MIICrjCCAjWgAwIBAgIQPLL0SAoA4v7rJDteYD7DazAKBggqhkjOPQQDAzCBmDELMAkGA1UEBhMC VVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsTMChjKSAyMDA3IEdlb1RydXN0IElu Yy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTE2MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFyeSBD ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEcyMB4XDTA3MTEwNTAwMDAwMFoXDTM4MDExODIzNTk1 OVowgZgxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAoYykg MjAwNyBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0BgNVBAMTLUdl b1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBHMjB2MBAGByqGSM49AgEG BSuBBAAiA2IABBWx6P0DFUPlrOuHNxFi79KDNlJ9RVcLSo17VDs6bl8VAsBQps8lL33KSLjHUGMc KiEIfJo22Av+0SbFWDEwKCXzXV2juLaltJLtbCyf691DiaI8S0iRHVDsJt/WYC69IaNCMEAwDwYD VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBVfNVdRVfslsq0DafwBo/q+ EVXVMAoGCCqGSM49BAMDA2cAMGQCMGSWWaboCd6LuvpaiIjwH5HTRqjySkwCY/tsXzjbLkGTqQ7m ndwxHLKgpxgceeHHNgIwOlavmnRs9vuD4DPTCF+hnMJbn0bWtsuRBmOiBuczrD6ogRLQy7rQkgu2 npaqBA+K -----END CERTIFICATE----- VeriSign Universal Root Certification Authority =============================================== -----BEGIN CERTIFICATE----- MIIEuTCCA6GgAwIBAgIQQBrEZCGzEyEDDrvkEhrFHTANBgkqhkiG9w0BAQsFADCBvTELMAkGA1UE BhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBUcnVzdCBO ZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwOCBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVk IHVzZSBvbmx5MTgwNgYDVQQDEy9WZXJpU2lnbiBVbml2ZXJzYWwgUm9vdCBDZXJ0aWZpY2F0aW9u IEF1dGhvcml0eTAeFw0wODA0MDIwMDAwMDBaFw0zNzEyMDEyMzU5NTlaMIG9MQswCQYDVQQGEwJV UzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRydXN0IE5ldHdv cmsxOjA4BgNVBAsTMShjKSAyMDA4IFZlcmlTaWduLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNl IG9ubHkxODA2BgNVBAMTL1ZlcmlTaWduIFVuaXZlcnNhbCBSb290IENlcnRpZmljYXRpb24gQXV0 aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAx2E3XrEBNNti1xWb/1hajCMj 1mCOkdeQmIN65lgZOIzF9uVkhbSicfvtvbnazU0AtMgtc6XHaXGVHzk8skQHnOgO+k1KxCHfKWGP MiJhgsWHH26MfF8WIFFE0XBPV+rjHOPMee5Y2A7Cs0WTwCznmhcrewA3ekEzeOEz4vMQGn+HLL72 9fdC4uW/h2KJXwBL38Xd5HVEMkE6HnFuacsLdUYI0crSK5XQz/u5QGtkjFdN/BMReYTtXlT2NJ8I AfMQJQYXStrxHXpma5hgZqTZ79IugvHw7wnqRMkVauIDbjPTrJ9VAMf2CGqUuV/c4DPxhGD5WycR tPwW8rtWaoAljQIDAQABo4GyMIGvMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMG0G CCsGAQUFBwEMBGEwX6FdoFswWTBXMFUWCWltYWdlL2dpZjAhMB8wBwYFKw4DAhoEFI/l0xqGrI2O a8PPgGrUSBgsexkuMCUWI2h0dHA6Ly9sb2dvLnZlcmlzaWduLmNvbS92c2xvZ28uZ2lmMB0GA1Ud DgQWBBS2d/ppSEefUxLVwuoHMnYH0ZcHGTANBgkqhkiG9w0BAQsFAAOCAQEASvj4sAPmLGd75JR3 Y8xuTPl9Dg3cyLk1uXBPY/ok+myDjEedO2Pzmvl2MpWRsXe8rJq+seQxIcaBlVZaDrHC1LGmWazx Y8u4TB1ZkErvkBYoH1quEPuBUDgMbMzxPcP1Y+Oz4yHJJDnp/RVmRvQbEdBNc6N9Rvk97ahfYtTx P/jgdFcrGJ2BtMQo2pSXpXDrrB2+BxHw1dvd5Yzw1TKwg+ZX4o+/vqGqvz0dtdQ46tewXDpPaj+P wGZsY6rp2aQW9IHRlRQOfc2VNNnSj3BzgXucfr2YYdhFh5iQxeuGMMY1v/D/w1WIg0vvBZIGcfK4 mJO37M2CYfE45k+XmCpajQ== -----END CERTIFICATE----- VeriSign Class 3 Public Primary Certification Authority - G4 ============================================================ -----BEGIN CERTIFICATE----- MIIDhDCCAwqgAwIBAgIQL4D+I4wOIg9IZxIokYesszAKBggqhkjOPQQDAzCByjELMAkGA1UEBhMC VVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBUcnVzdCBOZXR3 b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVz ZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmlj YXRpb24gQXV0aG9yaXR5IC0gRzQwHhcNMDcxMTA1MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCByjEL MAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBU cnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRo b3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5 IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzQwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAASnVnp8 Utpkmw4tXNherJI9/gHmGUo9FANL+mAnINmDiWn6VMaaGF5VKmTeBvaNSjutEDxlPZCIBIngMGGz rl0Bp3vefLK+ymVhAIau2o970ImtTR1ZmkGxvEeA3J5iw/mjgbIwga8wDwYDVR0TAQH/BAUwAwEB /zAOBgNVHQ8BAf8EBAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJaW1hZ2UvZ2lmMCEw HzAHBgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYjaHR0cDovL2xvZ28udmVyaXNpZ24u Y29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFLMWkf3upm7ktS5Jj4d4gYDs5bG1MAoGCCqGSM49BAMD A2gAMGUCMGYhDBgmYFo4e1ZC4Kf8NoRRkSAsdk1DPcQdhCPQrNZ8NQbOzWm9kA3bbEhCHQ6qQgIx AJw9SDkjOVgaFRJZap7v1VmyHVIsmXHNxynfGyphe3HR3vPA5Q06Sqotp9iGKt0uEA== -----END CERTIFICATE----- NetLock Arany (Class Gold) Főtanúsítvány ============================================ -----BEGIN CERTIFICATE----- MIIEFTCCAv2gAwIBAgIGSUEs5AAQMA0GCSqGSIb3DQEBCwUAMIGnMQswCQYDVQQGEwJIVTERMA8G A1UEBwwIQnVkYXBlc3QxFTATBgNVBAoMDE5ldExvY2sgS2Z0LjE3MDUGA1UECwwuVGFuw7pzw610 dsOhbnlraWFkw7NrIChDZXJ0aWZpY2F0aW9uIFNlcnZpY2VzKTE1MDMGA1UEAwwsTmV0TG9jayBB cmFueSAoQ2xhc3MgR29sZCkgRsWRdGFuw7pzw610dsOhbnkwHhcNMDgxMjExMTUwODIxWhcNMjgx MjA2MTUwODIxWjCBpzELMAkGA1UEBhMCSFUxETAPBgNVBAcMCEJ1ZGFwZXN0MRUwEwYDVQQKDAxO ZXRMb2NrIEtmdC4xNzA1BgNVBAsMLlRhbsO6c8OtdHbDoW55a2lhZMOzayAoQ2VydGlmaWNhdGlv biBTZXJ2aWNlcykxNTAzBgNVBAMMLE5ldExvY2sgQXJhbnkgKENsYXNzIEdvbGQpIEbFkXRhbsO6 c8OtdHbDoW55MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAxCRec75LbRTDofTjl5Bu 0jBFHjzuZ9lk4BqKf8owyoPjIMHj9DrTlF8afFttvzBPhCf2nx9JvMaZCpDyD/V/Q4Q3Y1GLeqVw /HpYzY6b7cNGbIRwXdrzAZAj/E4wqX7hJ2Pn7WQ8oLjJM2P+FpD/sLj916jAwJRDC7bVWaaeVtAk H3B5r9s5VA1lddkVQZQBr17s9o3x/61k/iCa11zr/qYfCGSji3ZVrR47KGAuhyXoqq8fxmRGILdw fzzeSNuWU7c5d+Qa4scWhHaXWy+7GRWF+GmF9ZmnqfI0p6m2pgP8b4Y9VHx2BJtr+UBdADTHLpl1 neWIA6pN+APSQnbAGwIDAKiLo0UwQzASBgNVHRMBAf8ECDAGAQH/AgEEMA4GA1UdDwEB/wQEAwIB BjAdBgNVHQ4EFgQUzPpnk/C2uNClwB7zU/2MU9+D15YwDQYJKoZIhvcNAQELBQADggEBAKt/7hwW qZw8UQCgwBEIBaeZ5m8BiFRhbvG5GK1Krf6BQCOUL/t1fC8oS2IkgYIL9WHxHG64YTjrgfpioTta YtOUZcTh5m2C+C8lcLIhJsFyUR+MLMOEkMNaj7rP9KdlpeuY0fsFskZ1FSNqb4VjMIDw1Z4fKRzC bLBQWV2QWzuoDTDPv31/zvGdg73JRm4gpvlhUbohL3u+pRVjodSVh/GeufOJ8z2FuLjbvrW5Kfna NwUASZQDhETnv0Mxz3WLJdH0pmT1kvarBes96aULNmLazAZfNou2XjG4Kvte9nHfRCaexOYNkbQu dZWAUWpLMKawYqGT8ZvYzsRjdT9ZR7E= -----END CERTIFICATE----- Staat der Nederlanden Root CA - G2 ================================== -----BEGIN CERTIFICATE----- MIIFyjCCA7KgAwIBAgIEAJiWjDANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJOTDEeMBwGA1UE CgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSswKQYDVQQDDCJTdGFhdCBkZXIgTmVkZXJsYW5kZW4g Um9vdCBDQSAtIEcyMB4XDTA4MDMyNjExMTgxN1oXDTIwMDMyNTExMDMxMFowWjELMAkGA1UEBhMC TkwxHjAcBgNVBAoMFVN0YWF0IGRlciBOZWRlcmxhbmRlbjErMCkGA1UEAwwiU3RhYXQgZGVyIE5l ZGVybGFuZGVuIFJvb3QgQ0EgLSBHMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMVZ 5291qj5LnLW4rJ4L5PnZyqtdj7U5EILXr1HgO+EASGrP2uEGQxGZqhQlEq0i6ABtQ8SpuOUfiUtn vWFI7/3S4GCI5bkYYCjDdyutsDeqN95kWSpGV+RLufg3fNU254DBtvPUZ5uW6M7XxgpT0GtJlvOj CwV3SPcl5XCsMBQgJeN/dVrlSPhOewMHBPqCYYdu8DvEpMfQ9XQ+pV0aCPKbJdL2rAQmPlU6Yiil e7Iwr/g3wtG61jj99O9JMDeZJiFIhQGp5Rbn3JBV3w/oOM2ZNyFPXfUib2rFEhZgF1XyZWampzCR OME4HYYEhLoaJXhena/MUGDWE4dS7WMfbWV9whUYdMrhfmQpjHLYFhN9C0lK8SgbIHRrxT3dsKpI CT0ugpTNGmXZK4iambwYfp/ufWZ8Pr2UuIHOzZgweMFvZ9C+X+Bo7d7iscksWXiSqt8rYGPy5V65 48r6f1CGPqI0GAwJaCgRHOThuVw+R7oyPxjMW4T182t0xHJ04eOLoEq9jWYv6q012iDTiIJh8BIi trzQ1aTsr1SIJSQ8p22xcik/Plemf1WvbibG/ufMQFxRRIEKeN5KzlW/HdXZt1bv8Hb/C3m1r737 qWmRRpdogBQ2HbN/uymYNqUg+oJgYjOk7Na6B6duxc8UpufWkjTYgfX8HV2qXB72o007uPc5AgMB AAGjgZcwgZQwDwYDVR0TAQH/BAUwAwEB/zBSBgNVHSAESzBJMEcGBFUdIAAwPzA9BggrBgEFBQcC ARYxaHR0cDovL3d3dy5wa2lvdmVyaGVpZC5ubC9wb2xpY2llcy9yb290LXBvbGljeS1HMjAOBgNV HQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJFoMocVHYnitfGsNig0jQt8YojrMA0GCSqGSIb3DQEBCwUA A4ICAQCoQUpnKpKBglBu4dfYszk78wIVCVBR7y29JHuIhjv5tLySCZa59sCrI2AGeYwRTlHSeYAz +51IvuxBQ4EffkdAHOV6CMqqi3WtFMTC6GY8ggen5ieCWxjmD27ZUD6KQhgpxrRW/FYQoAUXvQwj f/ST7ZwaUb7dRUG/kSS0H4zpX897IZmflZ85OkYcbPnNe5yQzSipx6lVu6xiNGI1E0sUOlWDuYaN kqbG9AclVMwWVxJKgnjIFNkXgiYtXSAfea7+1HAWFpWD2DU5/1JddRwWxRNVz0fMdWVSSt7wsKfk CpYL+63C4iWEst3kvX5ZbJvw8NjnyvLplzh+ib7M+zkXYT9y2zqR2GUBGR2tUKRXCnxLvJxxcypF URmFzI79R6d0lR2o0a9OF7FpJsKqeFdbxU2n5Z4FF5TKsl+gSRiNNOkmbEgeqmiSBeGCc1qb3Adb CG19ndeNIdn8FCCqwkXfP+cAslHkwvgFuXkajDTznlvkN1trSt8sV4pAWja63XVECDdCcAz+3F4h oKOKwJCcaNpQ5kUQR3i2TtJlycM33+FCY7BXN0Ute4qcvwXqZVUz9zkQxSgqIXobisQk+T8VyJoV IPVVYpbtbZNQvOSqeK3Zywplh6ZmwcSBo3c6WB4L7oOLnR7SUqTMHW+wmG2UMbX4cQrcufx9MmDm 66+KAQ== -----END CERTIFICATE----- CA Disig ======== -----BEGIN CERTIFICATE----- MIIEDzCCAvegAwIBAgIBATANBgkqhkiG9w0BAQUFADBKMQswCQYDVQQGEwJTSzETMBEGA1UEBxMK QnJhdGlzbGF2YTETMBEGA1UEChMKRGlzaWcgYS5zLjERMA8GA1UEAxMIQ0EgRGlzaWcwHhcNMDYw MzIyMDEzOTM0WhcNMTYwMzIyMDEzOTM0WjBKMQswCQYDVQQGEwJTSzETMBEGA1UEBxMKQnJhdGlz bGF2YTETMBEGA1UEChMKRGlzaWcgYS5zLjERMA8GA1UEAxMIQ0EgRGlzaWcwggEiMA0GCSqGSIb3 DQEBAQUAA4IBDwAwggEKAoIBAQCS9jHBfYj9mQGp2HvycXXxMcbzdWb6UShGhJd4NLxs/LxFWYgm GErENx+hSkS943EE9UQX4j/8SFhvXJ56CbpRNyIjZkMhsDxkovhqFQ4/61HhVKndBpnXmjxUizkD Pw/Fzsbrg3ICqB9x8y34dQjbYkzo+s7552oftms1grrijxaSfQUMbEYDXcDtab86wYqg6I7ZuUUo hwjstMoVvoLdtUSLLa2GDGhibYVW8qwUYzrG0ZmsNHhWS8+2rT+MitcE5eN4TPWGqvWP+j1scaMt ymfraHtuM6kMgiioTGohQBUgDCZbg8KpFhXAJIJdKxatymP2dACw30PEEGBWZ2NFAgMBAAGjgf8w gfwwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUjbJJaJ1yCCW5wCf1UJNWSEZx+Y8wDgYDVR0P AQH/BAQDAgEGMDYGA1UdEQQvMC2BE2Nhb3BlcmF0b3JAZGlzaWcuc2uGFmh0dHA6Ly93d3cuZGlz aWcuc2svY2EwZgYDVR0fBF8wXTAtoCugKYYnaHR0cDovL3d3dy5kaXNpZy5zay9jYS9jcmwvY2Ff ZGlzaWcuY3JsMCygKqAohiZodHRwOi8vY2EuZGlzaWcuc2svY2EvY3JsL2NhX2Rpc2lnLmNybDAa BgNVHSAEEzARMA8GDSuBHpGT5goAAAABAQEwDQYJKoZIhvcNAQEFBQADggEBAF00dGFMrzvY/59t WDYcPQuBDRIrRhCA/ec8J9B6yKm2fnQwM6M6int0wHl5QpNt/7EpFIKrIYwvF/k/Ji/1WcbvgAa3 mkkp7M5+cTxqEEHA9tOasnxakZzArFvITV734VP/Q3f8nktnbNfzg9Gg4H8l37iYC5oyOGwwoPP/ CBUz91BKez6jPiCp3C9WgArtQVCwyfTssuMmRAAOb54GvCKWU3BlxFAKRmukLyeBEicTXxChds6K ezfqwzlhA5WYOudsiCUI/HloDYd9Yvi0X/vF2Ey9WLw/Q1vUHgFNPGO+I++MzVpQuGhU+QqZMxEA 4Z7CRneC9VkGjCFMhwnN5ag= -----END CERTIFICATE----- Juur-SK ======= -----BEGIN CERTIFICATE----- MIIE5jCCA86gAwIBAgIEO45L/DANBgkqhkiG9w0BAQUFADBdMRgwFgYJKoZIhvcNAQkBFglwa2lA c2suZWUxCzAJBgNVBAYTAkVFMSIwIAYDVQQKExlBUyBTZXJ0aWZpdHNlZXJpbWlza2Vza3VzMRAw DgYDVQQDEwdKdXVyLVNLMB4XDTAxMDgzMDE0MjMwMVoXDTE2MDgyNjE0MjMwMVowXTEYMBYGCSqG SIb3DQEJARYJcGtpQHNrLmVlMQswCQYDVQQGEwJFRTEiMCAGA1UEChMZQVMgU2VydGlmaXRzZWVy aW1pc2tlc2t1czEQMA4GA1UEAxMHSnV1ci1TSzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC ggEBAIFxNj4zB9bjMI0TfncyRsvPGbJgMUaXhvSYRqTCZUXP00B841oiqBB4M8yIsdOBSvZiF3tf TQou0M+LI+5PAk676w7KvRhj6IAcjeEcjT3g/1tf6mTll+g/mX8MCgkzABpTpyHhOEvWgxutr2TC +Rx6jGZITWYfGAriPrsfB2WThbkasLnE+w0R9vXW+RvHLCu3GFH+4Hv2qEivbDtPL+/40UceJlfw UR0zlv/vWT3aTdEVNMfqPxZIe5EcgEMPPbgFPtGzlc3Yyg/CQ2fbt5PgIoIuvvVoKIO5wTtpeyDa Tpxt4brNj3pssAki14sL2xzVWiZbDcDq5WDQn/413z8CAwEAAaOCAawwggGoMA8GA1UdEwEB/wQF MAMBAf8wggEWBgNVHSAEggENMIIBCTCCAQUGCisGAQQBzh8BAQEwgfYwgdAGCCsGAQUFBwICMIHD HoHAAFMAZQBlACAAcwBlAHIAdABpAGYAaQBrAGEAYQB0ACAAbwBuACAAdgDkAGwAagBhAHMAdABh AHQAdQBkACAAQQBTAC0AaQBzACAAUwBlAHIAdABpAGYAaQB0AHMAZQBlAHIAaQBtAGkAcwBrAGUA cwBrAHUAcwAgAGEAbABhAG0ALQBTAEsAIABzAGUAcgB0AGkAZgBpAGsAYQBhAHQAaQBkAGUAIABr AGkAbgBuAGkAdABhAG0AaQBzAGUAawBzMCEGCCsGAQUFBwIBFhVodHRwOi8vd3d3LnNrLmVlL2Nw cy8wKwYDVR0fBCQwIjAgoB6gHIYaaHR0cDovL3d3dy5zay5lZS9qdXVyL2NybC8wHQYDVR0OBBYE FASqekej5ImvGs8KQKcYP2/v6X2+MB8GA1UdIwQYMBaAFASqekej5ImvGs8KQKcYP2/v6X2+MA4G A1UdDwEB/wQEAwIB5jANBgkqhkiG9w0BAQUFAAOCAQEAe8EYlFOiCfP+JmeaUOTDBS8rNXiRTHyo ERF5TElZrMj3hWVcRrs7EKACr81Ptcw2Kuxd/u+gkcm2k298gFTsxwhwDY77guwqYHhpNjbRxZyL abVAyJRld/JXIWY7zoVAtjNjGr95HvxcHdMdkxuLDF2FvZkwMhgJkVLpfKG6/2SSmuz+Ne6ML678 IIbsSt4beDI3poHSna9aEhbKmVv8b20OxaAehsmR0FyYgl9jDIpaq9iVpszLita/ZEuOyoqysOkh Mp6qqIWYNIE5ITuoOlIyPfZrN4YGWhWY3PARZv40ILcD9EEQfTmEeZZyY7aWAuVrua0ZTbvGRNs2 yyqcjg== -----END CERTIFICATE----- Hongkong Post Root CA 1 ======================= -----BEGIN CERTIFICATE----- MIIDMDCCAhigAwIBAgICA+gwDQYJKoZIhvcNAQEFBQAwRzELMAkGA1UEBhMCSEsxFjAUBgNVBAoT DUhvbmdrb25nIFBvc3QxIDAeBgNVBAMTF0hvbmdrb25nIFBvc3QgUm9vdCBDQSAxMB4XDTAzMDUx NTA1MTMxNFoXDTIzMDUxNTA0NTIyOVowRzELMAkGA1UEBhMCSEsxFjAUBgNVBAoTDUhvbmdrb25n IFBvc3QxIDAeBgNVBAMTF0hvbmdrb25nIFBvc3QgUm9vdCBDQSAxMIIBIjANBgkqhkiG9w0BAQEF AAOCAQ8AMIIBCgKCAQEArP84tulmAknjorThkPlAj3n54r15/gK97iSSHSL22oVyaf7XPwnU3ZG1 ApzQjVrhVcNQhrkpJsLj2aDxaQMoIIBFIi1WpztUlVYiWR8o3x8gPW2iNr4joLFutbEnPzlTCeqr auh0ssJlXI6/fMN4hM2eFvz1Lk8gKgifd/PFHsSaUmYeSF7jEAaPIpjhZY4bXSNmO7ilMlHIhqqh qZ5/dpTCpmy3QfDVyAY45tQM4vM7TG1QjMSDJ8EThFk9nnV0ttgCXjqQesBCNnLsak3c78QA3xMY V18meMjWCnl3v/evt3a5pQuEF10Q6m/hq5URX208o1xNg1vysxmKgIsLhwIDAQABoyYwJDASBgNV HRMBAf8ECDAGAQH/AgEDMA4GA1UdDwEB/wQEAwIBxjANBgkqhkiG9w0BAQUFAAOCAQEADkbVPK7i h9legYsCmEEIjEy82tvuJxuC52pF7BaLT4Wg87JwvVqWuspube5Gi27nKi6Wsxkz67SfqLI37pio l7Yutmcn1KZJ/RyTZXaeQi/cImyaT/JaFTmxcdcrUehtHJjA2Sr0oYJ71clBoiMBdDhViw+5Lmei IAQ32pwL0xch4I+XeTRvhEgCIDMb5jREn5Fw9IBehEPCKdJsEhTkYY2sEJCehFC78JZvRZ+K88ps T/oROhUVRsPNH4NbLUES7VBnQRM9IauUiqpOfMGx+6fWtScvl6tu4B3i0RwsH0Ti/L6RoZz71ilT c4afU9hDDl3WY4JxHYB0yvbiAmvZWg== -----END CERTIFICATE----- SecureSign RootCA11 =================== -----BEGIN CERTIFICATE----- MIIDbTCCAlWgAwIBAgIBATANBgkqhkiG9w0BAQUFADBYMQswCQYDVQQGEwJKUDErMCkGA1UEChMi SmFwYW4gQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcywgSW5jLjEcMBoGA1UEAxMTU2VjdXJlU2lnbiBS b290Q0ExMTAeFw0wOTA0MDgwNDU2NDdaFw0yOTA0MDgwNDU2NDdaMFgxCzAJBgNVBAYTAkpQMSsw KQYDVQQKEyJKYXBhbiBDZXJ0aWZpY2F0aW9uIFNlcnZpY2VzLCBJbmMuMRwwGgYDVQQDExNTZWN1 cmVTaWduIFJvb3RDQTExMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA/XeqpRyQBTvL TJszi1oURaTnkBbR31fSIRCkF/3frNYfp+TbfPfs37gD2pRY/V1yfIw/XwFndBWW4wI8h9uuywGO wvNmxoVF9ALGOrVisq/6nL+k5tSAMJjzDbaTj6nU2DbysPyKyiyhFTOVMdrAG/LuYpmGYz+/3ZMq g6h2uRMft85OQoWPIucuGvKVCbIFtUROd6EgvanyTgp9UK31BQ1FT0Zx/Sg+U/sE2C3XZR1KG/rP O7AxmjVuyIsG0wCR8pQIZUyxNAYAeoni8McDWc/V1uinMrPmmECGxc0nEovMe863ETxiYAcjPitA bpSACW22s293bzUIUPsCh8U+iQIDAQABo0IwQDAdBgNVHQ4EFgQUW/hNT7KlhtQ60vFjmqC+CfZX t94wDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAKCh OBZmLqdWHyGcBvod7bkixTgm2E5P7KN/ed5GIaGHd48HCJqypMWvDzKYC3xmKbabfSVSSUOrTC4r bnpwrxYO4wJs+0LmGJ1F2FXI6Dvd5+H0LgscNFxsWEr7jIhQX5Ucv+2rIrVls4W6ng+4reV6G4pQ Oh29Dbx7VFALuUKvVaAYga1lme++5Jy/xIWrQbJUb9wlze144o4MjQlJ3WN7WmmWAiGovVJZ6X01 y8hSyn+B/tlr0/cR7SXf+Of5pPpyl4RTDaXQMhhRdlkUbA/r7F+AjHVDg8OFmP9Mni0N5HeDk061 lgeLKBObjBmNQSdJQO7e5iNEOdyhIta6A/I= -----END CERTIFICATE----- ACEDICOM Root ============= -----BEGIN CERTIFICATE----- MIIFtTCCA52gAwIBAgIIYY3HhjsBggUwDQYJKoZIhvcNAQEFBQAwRDEWMBQGA1UEAwwNQUNFRElD T00gUm9vdDEMMAoGA1UECwwDUEtJMQ8wDQYDVQQKDAZFRElDT00xCzAJBgNVBAYTAkVTMB4XDTA4 MDQxODE2MjQyMloXDTI4MDQxMzE2MjQyMlowRDEWMBQGA1UEAwwNQUNFRElDT00gUm9vdDEMMAoG A1UECwwDUEtJMQ8wDQYDVQQKDAZFRElDT00xCzAJBgNVBAYTAkVTMIICIjANBgkqhkiG9w0BAQEF AAOCAg8AMIICCgKCAgEA/5KV4WgGdrQsyFhIyv2AVClVYyT/kGWbEHV7w2rbYgIB8hiGtXxaOLHk WLn709gtn70yN78sFW2+tfQh0hOR2QetAQXW8713zl9CgQr5auODAKgrLlUTY4HKRxx7XBZXehuD YAQ6PmXDzQHe3qTWDLqO3tkE7hdWIpuPY/1NFgu3e3eM+SW10W2ZEi5PGrjm6gSSrj0RuVFCPYew MYWveVqc/udOXpJPQ/yrOq2lEiZmueIM15jO1FillUAKt0SdE3QrwqXrIhWYENiLxQSfHY9g5QYb m8+5eaA9oiM/Qj9r+hwDezCNzmzAv+YbX79nuIQZ1RXve8uQNjFiybwCq0Zfm/4aaJQ0PZCOrfbk HQl/Sog4P75n/TSW9R28MHTLOO7VbKvU/PQAtwBbhTIWdjPp2KOZnQUAqhbm84F9b32qhm2tFXTT xKJxqvQUfecyuB+81fFOvW8XAjnXDpVCOscAPukmYxHqC9FK/xidstd7LzrZlvvoHpKuE1XI2Sf2 3EgbsCTBheN3nZqk8wwRHQ3ItBTutYJXCb8gWH8vIiPYcMt5bMlL8qkqyPyHK9caUPgn6C9D4zq9 2Fdx/c6mUlv53U3t5fZvie27k5x2IXXwkkwp9y+cAS7+UEaeZAwUswdbxcJzbPEHXEUkFDWug/Fq TYl6+rPYLWbwNof1K1MCAwEAAaOBqjCBpzAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFKaz 4SsrSbbXc6GqlPUB53NlTKxQMA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQUprPhKytJttdzoaqU 9QHnc2VMrFAwRAYDVR0gBD0wOzA5BgRVHSAAMDEwLwYIKwYBBQUHAgEWI2h0dHA6Ly9hY2VkaWNv bS5lZGljb21ncm91cC5jb20vZG9jMA0GCSqGSIb3DQEBBQUAA4ICAQDOLAtSUWImfQwng4/F9tqg aHtPkl7qpHMyEVNEskTLnewPeUKzEKbHDZ3Ltvo/Onzqv4hTGzz3gvoFNTPhNahXwOf9jU8/kzJP eGYDdwdY6ZXIfj7QeQCM8htRM5u8lOk6e25SLTKeI6RF+7YuE7CLGLHdztUdp0J/Vb77W7tH1Pwk zQSulgUV1qzOMPPKC8W64iLgpq0i5ALudBF/TP94HTXa5gI06xgSYXcGCRZj6hitoocf8seACQl1 ThCojz2GuHURwCRiipZ7SkXp7FnFvmuD5uHorLUwHv4FB4D54SMNUI8FmP8sX+g7tq3PgbUhh8oI KiMnMCArz+2UW6yyetLHKKGKC5tNSixthT8Jcjxn4tncB7rrZXtaAWPWkFtPF2Y9fwsZo5NjEFIq nxQWWOLcpfShFosOkYuByptZ+thrkQdlVV9SH686+5DdaaVbnG0OLLb6zqylfDJKZ0DcMDQj3dcE I2bw/FWAp/tmGYI1Z2JwOV5vx+qQQEQIHriy1tvuWacNGHk0vFQYXlPKNFHtRQrmjseCNj6nOGOp MCwXEGCSn1WHElkQwg9naRHMTh5+Spqtr0CodaxWkHS4oJyleW/c6RrIaQXpuvoDs3zk4E7Czp3o tkYNbn5XOmeUwssfnHdKZ05phkOTOPu220+DkdRgfks+KzgHVZhepA== -----END CERTIFICATE----- Verisign Class 3 Public Primary Certification Authority ======================================================= -----BEGIN CERTIFICATE----- MIICPDCCAaUCEDyRMcsf9tAbDpq40ES/Er4wDQYJKoZIhvcNAQEFBQAwXzELMAkGA1UEBhMCVVMx FzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFzcyAzIFB1YmxpYyBQcmltYXJ5 IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTk2MDEyOTAwMDAwMFoXDTI4MDgwMjIzNTk1OVow XzELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFzcyAz IFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIGfMA0GCSqGSIb3DQEBAQUA A4GNADCBiQKBgQDJXFme8huKARS0EN8EQNvjV69qRUCPhAwL0TPZ2RHP7gJYHyX3KqhEBarsAx94 f56TuZoAqiN91qyFomNFx3InzPRMxnVx0jnvT0Lwdd8KkMaOIG+YD/isI19wKTakyYbnsZogy1Ol hec9vn2a/iRFM9x2Fe0PonFkTGUugWhFpwIDAQABMA0GCSqGSIb3DQEBBQUAA4GBABByUqkFFBky CEHwxWsKzH4PIRnN5GfcX6kb5sroc50i2JhucwNhkcV8sEVAbkSdjbCxlnRhLQ2pRdKkkirWmnWX bj9T/UWZYB2oK0z5XqcJ2HUw19JlYD1n1khVdWk/kfVIC0dpImmClr7JyDiGSnoscxlIaU5rfGW/ D/xwzoiQ -----END CERTIFICATE----- Microsec e-Szigno Root CA 2009 ============================== -----BEGIN CERTIFICATE----- MIIECjCCAvKgAwIBAgIJAMJ+QwRORz8ZMA0GCSqGSIb3DQEBCwUAMIGCMQswCQYDVQQGEwJIVTER MA8GA1UEBwwIQnVkYXBlc3QxFjAUBgNVBAoMDU1pY3Jvc2VjIEx0ZC4xJzAlBgNVBAMMHk1pY3Jv c2VjIGUtU3ppZ25vIFJvb3QgQ0EgMjAwOTEfMB0GCSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5o dTAeFw0wOTA2MTYxMTMwMThaFw0yOTEyMzAxMTMwMThaMIGCMQswCQYDVQQGEwJIVTERMA8GA1UE BwwIQnVkYXBlc3QxFjAUBgNVBAoMDU1pY3Jvc2VjIEx0ZC4xJzAlBgNVBAMMHk1pY3Jvc2VjIGUt U3ppZ25vIFJvb3QgQ0EgMjAwOTEfMB0GCSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5odTCCASIw DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOn4j/NjrdqG2KfgQvvPkd6mJviZpWNwrZuuyjNA fW2WbqEORO7hE52UQlKavXWFdCyoDh2Tthi3jCyoz/tccbna7P7ofo/kLx2yqHWH2Leh5TvPmUpG 0IMZfcChEhyVbUr02MelTTMuhTlAdX4UfIASmFDHQWe4oIBhVKZsTh/gnQ4H6cm6M+f+wFUoLAKA pxn1ntxVUwOXewdI/5n7N4okxFnMUBBjjqqpGrCEGob5X7uxUG6k0QrM1XF+H6cbfPVTbiJfyyvm 1HxdrtbCxkzlBQHZ7Vf8wSN5/PrIJIOV87VqUQHQd9bpEqH5GoP7ghu5sJf0dgYzQ0mg/wu1+rUC AwEAAaOBgDB+MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTLD8bf QkPMPcu1SCOhGnqmKrs0aDAfBgNVHSMEGDAWgBTLD8bfQkPMPcu1SCOhGnqmKrs0aDAbBgNVHREE FDASgRBpbmZvQGUtc3ppZ25vLmh1MA0GCSqGSIb3DQEBCwUAA4IBAQDJ0Q5eLtXMs3w+y/w9/w0o lZMEyL/azXm4Q5DwpL7v8u8hmLzU1F0G9u5C7DBsoKqpyvGvivo/C3NqPuouQH4frlRheesuCDfX I/OMn74dseGkddug4lQUsbocKaQY9hK6ohQU4zE1yED/t+AFdlfBHFny+L/k7SViXITwfn4fs775 tyERzAMBVnCnEJIeGzSBHq2cGsMEPO0CYdYeBvNfOofyK/FFh+U9rNHHV4S9a67c2Pm2G2JwCz02 yULyMtd6YebS2z3PyKnJm9zbWETXbzivf3jTo60adbocwTZ8jx5tHMN1Rq41Bab2XD0h7lbwyYIi LXpUq3DDfSJlgnCW -----END CERTIFICATE----- E-Guven Kok Elektronik Sertifika Hizmet Saglayicisi =================================================== -----BEGIN CERTIFICATE----- MIIDtjCCAp6gAwIBAgIQRJmNPMADJ72cdpW56tustTANBgkqhkiG9w0BAQUFADB1MQswCQYDVQQG EwJUUjEoMCYGA1UEChMfRWxla3Ryb25payBCaWxnaSBHdXZlbmxpZ2kgQS5TLjE8MDoGA1UEAxMz ZS1HdXZlbiBLb2sgRWxla3Ryb25payBTZXJ0aWZpa2EgSGl6bWV0IFNhZ2xheWljaXNpMB4XDTA3 MDEwNDExMzI0OFoXDTE3MDEwNDExMzI0OFowdTELMAkGA1UEBhMCVFIxKDAmBgNVBAoTH0VsZWt0 cm9uaWsgQmlsZ2kgR3V2ZW5saWdpIEEuUy4xPDA6BgNVBAMTM2UtR3V2ZW4gS29rIEVsZWt0cm9u aWsgU2VydGlmaWthIEhpem1ldCBTYWdsYXlpY2lzaTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC AQoCggEBAMMSIJ6wXgBljU5Gu4Bc6SwGl9XzcslwuedLZYDBS75+PNdUMZTe1RK6UxYC6lhj71vY 8+0qGqpxSKPcEC1fX+tcS5yWCEIlKBHMilpiAVDV6wlTL/jDj/6z/P2douNffb7tC+Bg62nsM+3Y jfsSSYMAyYuXjDtzKjKzEve5TfL0TW3H5tYmNwjy2f1rXKPlSFxYvEK+A1qBuhw1DADT9SN+cTAI JjjcJRFHLfO6IxClv7wC90Nex/6wN1CZew+TzuZDLMN+DfIcQ2Zgy2ExR4ejT669VmxMvLz4Bcpk 9Ok0oSy1c+HCPujIyTQlCFzz7abHlJ+tiEMl1+E5YP6sOVkCAwEAAaNCMEAwDgYDVR0PAQH/BAQD AgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFJ/uRLOU1fqRTy7ZVZoEVtstxNulMA0GCSqG SIb3DQEBBQUAA4IBAQB/X7lTW2M9dTLn+sR0GstG30ZpHFLPqk/CaOv/gKlR6D1id4k9CnU58W5d F4dvaAXBlGzZXd/aslnLpRCKysw5zZ/rTt5S/wzw9JKp8mxTq5vSR6AfdPebmvEvFZ96ZDAYBzwq D2fK/A+JYZ1lpTzlvBNbCNvj/+27BrtqBrF6T2XGgv0enIu1De5Iu7i9qgi0+6N8y5/NkHZchpZ4 Vwpm+Vganf2XKWDeEaaQHBkc7gGWIjQ0LpH5t8Qn0Xvmv/uARFoW5evg1Ao4vOSR49XrXMGs3xtq fJ7lddK2l4fbzIcrQzqECK+rPNv3PGYxhrCdU3nt+CPeQuMtgvEP5fqX -----END CERTIFICATE----- GlobalSign Root CA - R3 ======================= -----BEGIN CERTIFICATE----- MIIDXzCCAkegAwIBAgILBAAAAAABIVhTCKIwDQYJKoZIhvcNAQELBQAwTDEgMB4GA1UECxMXR2xv YmFsU2lnbiBSb290IENBIC0gUjMxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkdsb2Jh bFNpZ24wHhcNMDkwMzE4MTAwMDAwWhcNMjkwMzE4MTAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxT aWduIFJvb3QgQ0EgLSBSMzETMBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2ln bjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMwldpB5BngiFvXAg7aEyiie/QV2EcWt iHL8RgJDx7KKnQRfJMsuS+FggkbhUqsMgUdwbN1k0ev1LKMPgj0MK66X17YUhhB5uzsTgHeMCOFJ 0mpiLx9e+pZo34knlTifBtc+ycsmWQ1z3rDI6SYOgxXG71uL0gRgykmmKPZpO/bLyCiR5Z2KYVc3 rHQU3HTgOu5yLy6c+9C7v/U9AOEGM+iCK65TpjoWc4zdQQ4gOsC0p6Hpsk+QLjJg6VfLuQSSaGjl OCZgdbKfd/+RFO+uIEn8rUAVSNECMWEZXriX7613t2Saer9fwRPvm2L7DWzgVGkWqQPabumDk3F2 xmmFghcCAwEAAaNCMEAwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYE FI/wS3+oLkUkrk1Q+mOai97i3Ru8MA0GCSqGSIb3DQEBCwUAA4IBAQBLQNvAUKr+yAzv95ZURUm7 lgAJQayzE4aGKAczymvmdLm6AC2upArT9fHxD4q/c2dKg8dEe3jgr25sbwMpjjM5RcOO5LlXbKr8 EpbsU8Yt5CRsuZRj+9xTaGdWPoO4zzUhw8lo/s7awlOqzJCK6fBdRoyV3XpYKBovHd7NADdBj+1E bddTKJd+82cEHhXXipa0095MJ6RMG3NzdvQXmcIfeg7jLQitChws/zyrVQ4PkX4268NXSb7hLi18 YIvDQVETI53O9zJrlAGomecsMx86OyXShkDOOyyGeMlhLxS67ttVb9+E7gUJTb0o2HLO02JQZR7r kpeDMdmztcpHWD9f -----END CERTIFICATE----- TC TrustCenter Universal CA III =============================== -----BEGIN CERTIFICATE----- MIID4TCCAsmgAwIBAgIOYyUAAQACFI0zFQLkbPQwDQYJKoZIhvcNAQEFBQAwezELMAkGA1UEBhMC REUxHDAaBgNVBAoTE1RDIFRydXN0Q2VudGVyIEdtYkgxJDAiBgNVBAsTG1RDIFRydXN0Q2VudGVy IFVuaXZlcnNhbCBDQTEoMCYGA1UEAxMfVEMgVHJ1c3RDZW50ZXIgVW5pdmVyc2FsIENBIElJSTAe Fw0wOTA5MDkwODE1MjdaFw0yOTEyMzEyMzU5NTlaMHsxCzAJBgNVBAYTAkRFMRwwGgYDVQQKExNU QyBUcnVzdENlbnRlciBHbWJIMSQwIgYDVQQLExtUQyBUcnVzdENlbnRlciBVbml2ZXJzYWwgQ0Ex KDAmBgNVBAMTH1RDIFRydXN0Q2VudGVyIFVuaXZlcnNhbCBDQSBJSUkwggEiMA0GCSqGSIb3DQEB AQUAA4IBDwAwggEKAoIBAQDC2pxisLlxErALyBpXsq6DFJmzNEubkKLF5+cvAqBNLaT6hdqbJYUt QCggbergvbFIgyIpRJ9Og+41URNzdNW88jBmlFPAQDYvDIRlzg9uwliT6CwLOunBjvvya8o84pxO juT5fdMnnxvVZ3iHLX8LR7PH6MlIfK8vzArZQe+f/prhsq75U7Xl6UafYOPfjdN/+5Z+s7Vy+Eut CHnNaYlAJ/Uqwa1D7KRTyGG299J5KmcYdkhtWyUB0SbFt1dpIxVbYYqt8Bst2a9c8SaQaanVDED1 M4BDj5yjdipFtK+/fz6HP3bFzSreIMUWWMv5G/UPyw0RUmS40nZid4PxWJ//AgMBAAGjYzBhMB8G A1UdIwQYMBaAFFbn4VslQ4Dg9ozhcbyO5YAvxEjiMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/ BAQDAgEGMB0GA1UdDgQWBBRW5+FbJUOA4PaM4XG8juWAL8RI4jANBgkqhkiG9w0BAQUFAAOCAQEA g8ev6n9NCjw5sWi+e22JLumzCecYV42FmhfzdkJQEw/HkG8zrcVJYCtsSVgZ1OK+t7+rSbyUyKu+ KGwWaODIl0YgoGhnYIg5IFHYaAERzqf2EQf27OysGh+yZm5WZ2B6dF7AbZc2rrUNXWZzwCUyRdhK BgePxLcHsU0GDeGl6/R1yrqc0L2z0zIkTO5+4nYES0lT2PLpVDP85XEfPRRclkvxOvIAu2y0+pZV CIgJwcyRGSmwIC3/yzikQOEXvnlhgP8HA4ZMTnsGnxGGjYnuJ8Tb4rwZjgvDwxPHLQNjO9Po5KIq woIIlBZU8O8fJ5AluA0OKBtHd0e9HKgl8ZS0Zg== -----END CERTIFICATE----- Autoridad de Certificacion Firmaprofesional CIF A62634068 ========================================================= -----BEGIN CERTIFICATE----- MIIGFDCCA/ygAwIBAgIIU+w77vuySF8wDQYJKoZIhvcNAQEFBQAwUTELMAkGA1UEBhMCRVMxQjBA BgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1hcHJvZmVzaW9uYWwgQ0lGIEE2 MjYzNDA2ODAeFw0wOTA1MjAwODM4MTVaFw0zMDEyMzEwODM4MTVaMFExCzAJBgNVBAYTAkVTMUIw QAYDVQQDDDlBdXRvcmlkYWQgZGUgQ2VydGlmaWNhY2lvbiBGaXJtYXByb2Zlc2lvbmFsIENJRiBB NjI2MzQwNjgwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKlmuO6vj78aI14H9M2uDD Utd9thDIAl6zQyrET2qyyhxdKJp4ERppWVevtSBC5IsP5t9bpgOSL/UR5GLXMnE42QQMcas9UX4P B99jBVzpv5RvwSmCwLTaUbDBPLutN0pcyvFLNg4kq7/DhHf9qFD0sefGL9ItWY16Ck6WaVICqjaY 7Pz6FIMMNx/Jkjd/14Et5cS54D40/mf0PmbR0/RAz15iNA9wBj4gGFrO93IbJWyTdBSTo3OxDqqH ECNZXyAFGUftaI6SEspd/NYrspI8IM/hX68gvqB2f3bl7BqGYTM+53u0P6APjqK5am+5hyZvQWyI plD9amML9ZMWGxmPsu2bm8mQ9QEM3xk9Dz44I8kvjwzRAv4bVdZO0I08r0+k8/6vKtMFnXkIoctX MbScyJCyZ/QYFpM6/EfY0XiWMR+6KwxfXZmtY4laJCB22N/9q06mIqqdXuYnin1oKaPnirjaEbsX LZmdEyRG98Xi2J+Of8ePdG1asuhy9azuJBCtLxTa/y2aRnFHvkLfuwHb9H/TKI8xWVvTyQKmtFLK bpf7Q8UIJm+K9Lv9nyiqDdVF8xM6HdjAeI9BZzwelGSuewvF6NkBiDkal4ZkQdU7hwxu+g/GvUgU vzlN1J5Bto+WHWOWk9mVBngxaJ43BjuAiUVhOSPHG0SjFeUc+JIwuwIDAQABo4HvMIHsMBIGA1Ud EwEB/wQIMAYBAf8CAQEwDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRlzeurNR4APn7VdMActHNH DhpkLzCBpgYDVR0gBIGeMIGbMIGYBgRVHSAAMIGPMC8GCCsGAQUFBwIBFiNodHRwOi8vd3d3LmZp cm1hcHJvZmVzaW9uYWwuY29tL2NwczBcBggrBgEFBQcCAjBQHk4AUABhAHMAZQBvACAAZABlACAA bABhACAAQgBvAG4AYQBuAG8AdgBhACAANAA3ACAAQgBhAHIAYwBlAGwAbwBuAGEAIAAwADgAMAAx ADcwDQYJKoZIhvcNAQEFBQADggIBABd9oPm03cXF661LJLWhAqvdpYhKsg9VSytXjDvlMd3+xDLx 51tkljYyGOylMnfX40S2wBEqgLk9am58m9Ot/MPWo+ZkKXzR4Tgegiv/J2Wv+xYVxC5xhOW1//qk R71kMrv2JYSiJ0L1ILDCExARzRAVukKQKtJE4ZYm6zFIEv0q2skGz3QeqUvVhyj5eTSSPi5E6PaP T481PyWzOdxjKpBrIF/EUhJOlywqrJ2X3kjyo2bbwtKDlaZmp54lD+kLM5FlClrD2VQS3a/DTg4f Jl4N3LON7NWBcN7STyQF82xO9UxJZo3R/9ILJUFI/lGExkKvgATP0H5kSeTy36LssUzAKh3ntLFl osS88Zj0qnAHY7S42jtM+kAiMFsRpvAFDsYCA0irhpuF3dvd6qJ2gHN99ZwExEWN57kci57q13XR crHedUTnQn3iV2t93Jm8PYMo6oCTjcVMZcFwgbg4/EMxsvYDNEeyrPsiBsse3RdHHF9mudMaotoR saS8I8nkvof/uZS2+F0gStRf571oe2XyFR7SOqkt6dhrJKyXWERHrVkY8SFlcN7ONGCoQPHzPKTD KCOM/iczQ0CgFzzr6juwcqajuUpLXhZI9LK8yIySxZ2frHI2vDSANGupi5LAuBft7HZT9SQBjLMi 6Et8Vcad+qMUu2WFbm5PEn4KPJ2V -----END CERTIFICATE----- Izenpe.com ========== -----BEGIN CERTIFICATE----- MIIF8TCCA9mgAwIBAgIQALC3WhZIX7/hy/WL1xnmfTANBgkqhkiG9w0BAQsFADA4MQswCQYDVQQG EwJFUzEUMBIGA1UECgwLSVpFTlBFIFMuQS4xEzARBgNVBAMMCkl6ZW5wZS5jb20wHhcNMDcxMjEz MTMwODI4WhcNMzcxMjEzMDgyNzI1WjA4MQswCQYDVQQGEwJFUzEUMBIGA1UECgwLSVpFTlBFIFMu QS4xEzARBgNVBAMMCkl6ZW5wZS5jb20wggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDJ 03rKDx6sp4boFmVqscIbRTJxldn+EFvMr+eleQGPicPK8lVx93e+d5TzcqQsRNiekpsUOqHnJJAK ClaOxdgmlOHZSOEtPtoKct2jmRXagaKH9HtuJneJWK3W6wyyQXpzbm3benhB6QiIEn6HLmYRY2xU +zydcsC8Lv/Ct90NduM61/e0aL6i9eOBbsFGb12N4E3GVFWJGjMxCrFXuaOKmMPsOzTFlUFpfnXC PCDFYbpRR6AgkJOhkEvzTnyFRVSa0QUmQbC1TR0zvsQDyCV8wXDbO/QJLVQnSKwv4cSsPsjLkkxT OTcj7NMB+eAJRE1NZMDhDVqHIrytG6P+JrUV86f8hBnp7KGItERphIPzidF0BqnMC9bC3ieFUCbK F7jJeodWLBoBHmy+E60QrLUk9TiRodZL2vG70t5HtfG8gfZZa88ZU+mNFctKy6lvROUbQc/hhqfK 0GqfvEyNBjNaooXlkDWgYlwWTvDjovoDGrQscbNYLN57C9saD+veIR8GdwYDsMnvmfzAuU8Lhij+ 0rnq49qlw0dpEuDb8PYZi+17cNcC1u2HGCgsBCRMd+RIihrGO5rUD8r6ddIBQFqNeb+Lz0vPqhbB leStTIo+F5HUsWLlguWABKQDfo2/2n+iD5dPDNMN+9fR5XJ+HMh3/1uaD7euBUbl8agW7EekFwID AQABo4H2MIHzMIGwBgNVHREEgagwgaWBD2luZm9AaXplbnBlLmNvbaSBkTCBjjFHMEUGA1UECgw+ SVpFTlBFIFMuQS4gLSBDSUYgQTAxMzM3MjYwLVJNZXJjLlZpdG9yaWEtR2FzdGVpeiBUMTA1NSBG NjIgUzgxQzBBBgNVBAkMOkF2ZGEgZGVsIE1lZGl0ZXJyYW5lbyBFdG9yYmlkZWEgMTQgLSAwMTAx MCBWaXRvcmlhLUdhc3RlaXowDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0O BBYEFB0cZQ6o8iV7tJHP5LGx5r1VdGwFMA0GCSqGSIb3DQEBCwUAA4ICAQB4pgwWSp9MiDrAyw6l Fn2fuUhfGI8NYjb2zRlrrKvV9pF9rnHzP7MOeIWblaQnIUdCSnxIOvVFfLMMjlF4rJUT3sb9fbga kEyrkgPH7UIBzg/YsfqikuFgba56awmqxinuaElnMIAkejEWOVt+8Rwu3WwJrfIxwYJOubv5vr8q hT/AQKM6WfxZSzwoJNu0FXWuDYi6LnPAvViH5ULy617uHjAimcs30cQhbIHsvm0m5hzkQiCeR7Cs g1lwLDXWrzY0tM07+DKo7+N4ifuNRSzanLh+QBxh5z6ikixL8s36mLYp//Pye6kfLqCTVyvehQP5 aTfLnnhqBbTFMXiJ7HqnheG5ezzevh55hM6fcA5ZwjUukCox2eRFekGkLhObNA5me0mrZJfQRsN5 nXJQY6aYWwa9SG3YOYNw6DXwBdGqvOPbyALqfP2C2sJbUjWumDqtujWTI6cfSN01RpiyEGjkpTHC ClguGYEQyVB1/OpaFs4R1+7vUIgtYf8/QnMFlEPVjjxOAToZpR9GTnfQXeWBIiGH/pR9hNiTrdZo Q0iy2+tzJOeRf1SktoA+naM8THLCV8Sg1Mw4J87VBp6iSNnpn86CcDaTmjvfliHjWbcM2pE38P1Z WrOZyGlsQyYBNWNgVYkDOnXYukrZVP/u3oDYLdE41V4tC5h9Pmzb/CaIxw== -----END CERTIFICATE----- Chambers of Commerce Root - 2008 ================================ -----BEGIN CERTIFICATE----- MIIHTzCCBTegAwIBAgIJAKPaQn6ksa7aMA0GCSqGSIb3DQEBBQUAMIGuMQswCQYDVQQGEwJFVTFD MEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNv bS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMu QS4xKTAnBgNVBAMTIENoYW1iZXJzIG9mIENvbW1lcmNlIFJvb3QgLSAyMDA4MB4XDTA4MDgwMTEy Mjk1MFoXDTM4MDczMTEyMjk1MFowga4xCzAJBgNVBAYTAkVVMUMwQQYDVQQHEzpNYWRyaWQgKHNl ZSBjdXJyZW50IGFkZHJlc3MgYXQgd3d3LmNhbWVyZmlybWEuY29tL2FkZHJlc3MpMRIwEAYDVQQF EwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENhbWVyZmlybWEgUy5BLjEpMCcGA1UEAxMgQ2hhbWJl cnMgb2YgQ29tbWVyY2UgUm9vdCAtIDIwMDgwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC AQCvAMtwNyuAWko6bHiUfaN/Gh/2NdW928sNRHI+JrKQUrpjOyhYb6WzbZSm891kDFX29ufyIiKA XuFixrYp4YFs8r/lfTJqVKAyGVn+H4vXPWCGhSRv4xGzdz4gljUha7MI2XAuZPeEklPWDrCQiorj h40G072QDuKZoRuGDtqaCrsLYVAGUvGef3bsyw/QHg3PmTA9HMRFEFis1tPo1+XqxQEHd9ZR5gN/ ikilTWh1uem8nk4ZcfUyS5xtYBkL+8ydddy/Js2Pk3g5eXNeJQ7KXOt3EgfLZEFHcpOrUMPrCXZk NNI5t3YRCQ12RcSprj1qr7V9ZS+UWBDsXHyvfuK2GNnQm05aSd+pZgvMPMZ4fKecHePOjlO+Bd5g D2vlGts/4+EhySnB8esHnFIbAURRPHsl18TlUlRdJQfKFiC4reRB7noI/plvg6aRArBsNlVq5331 lubKgdaX8ZSD6e2wsWsSaR6s+12pxZjptFtYer49okQ6Y1nUCyXeG0+95QGezdIp1Z8XGQpvvwyQ 0wlf2eOKNcx5Wk0ZN5K3xMGtr/R5JJqyAQuxr1yW84Ay+1w9mPGgP0revq+ULtlVmhduYJ1jbLhj ya6BXBg14JC7vjxPNyK5fuvPnnchpj04gftI2jE9K+OJ9dC1vX7gUMQSibMjmhAxhduub+84Mxh2 EQIDAQABo4IBbDCCAWgwEgYDVR0TAQH/BAgwBgEB/wIBDDAdBgNVHQ4EFgQU+SSsD7K1+HnA+mCI G8TZTQKeFxkwgeMGA1UdIwSB2zCB2IAU+SSsD7K1+HnA+mCIG8TZTQKeFxmhgbSkgbEwga4xCzAJ BgNVBAYTAkVVMUMwQQYDVQQHEzpNYWRyaWQgKHNlZSBjdXJyZW50IGFkZHJlc3MgYXQgd3d3LmNh bWVyZmlybWEuY29tL2FkZHJlc3MpMRIwEAYDVQQFEwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENh bWVyZmlybWEgUy5BLjEpMCcGA1UEAxMgQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdCAtIDIwMDiC CQCj2kJ+pLGu2jAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRVHSAAMCowKAYIKwYBBQUH AgEWHGh0dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20wDQYJKoZIhvcNAQEFBQADggIBAJASryI1 wqM58C7e6bXpeHxIvj99RZJe6dqxGfwWPJ+0W2aeaufDuV2I6A+tzyMP3iU6XsxPpcG1Lawk0lgH 3qLPaYRgM+gQDROpI9CF5Y57pp49chNyM/WqfcZjHwj0/gF/JM8rLFQJ3uIrbZLGOU8W6jx+ekbU RWpGqOt1glanq6B8aBMz9p0w8G8nOSQjKpD9kCk18pPfNKXG9/jvjA9iSnyu0/VU+I22mlaHFoI6 M6taIgj3grrqLuBHmrS1RaMFO9ncLkVAO+rcf+g769HsJtg1pDDFOqxXnrN2pSB7+R5KBWIBpih1 YJeSDW4+TTdDDZIVnBgizVGZoCkaPF+KMjNbMMeJL0eYD6MDxvbxrN8y8NmBGuScvfaAFPDRLLmF 9dijscilIeUcE5fuDr3fKanvNFNb0+RqE4QGtjICxFKuItLcsiFCGtpA8CnJ7AoMXOLQusxI0zcK zBIKinmwPQN/aUv0NCB9szTqjktk9T79syNnFQ0EuPAtwQlRPLJsFfClI9eDdOTlLsn+mCdCxqvG nrDQWzilm1DefhiYtUU79nm06PcaewaD+9CL2rvHvRirCG88gGtAPxkZumWK5r7VXNM21+9AUiRg OGcEMeyP84LG3rlV8zsxkVrctQgVrXYlCg17LofiDKYGvCYQbTed7N14jHyAxfDZd0jQ -----END CERTIFICATE----- Global Chambersign Root - 2008 ============================== -----BEGIN CERTIFICATE----- MIIHSTCCBTGgAwIBAgIJAMnN0+nVfSPOMA0GCSqGSIb3DQEBBQUAMIGsMQswCQYDVQQGEwJFVTFD MEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNv bS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMu QS4xJzAlBgNVBAMTHkdsb2JhbCBDaGFtYmVyc2lnbiBSb290IC0gMjAwODAeFw0wODA4MDExMjMx NDBaFw0zODA3MzExMjMxNDBaMIGsMQswCQYDVQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUg Y3VycmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAGA1UEBRMJ QTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xJzAlBgNVBAMTHkdsb2JhbCBD aGFtYmVyc2lnbiBSb290IC0gMjAwODCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMDf VtPkOpt2RbQT2//BthmLN0EYlVJH6xedKYiONWwGMi5HYvNJBL99RDaxccy9Wglz1dmFRP+RVyXf XjaOcNFccUMd2drvXNL7G706tcuto8xEpw2uIRU/uXpbknXYpBI4iRmKt4DS4jJvVpyR1ogQC7N0 ZJJ0YPP2zxhPYLIj0Mc7zmFLmY/CDNBAspjcDahOo7kKrmCgrUVSY7pmvWjg+b4aqIG7HkF4ddPB /gBVsIdU6CeQNR1MM62X/JcumIS/LMmjv9GYERTtY/jKmIhYF5ntRQOXfjyGHoiMvvKRhI9lNNgA TH23MRdaKXoKGCQwoze1eqkBfSbW+Q6OWfH9GzO1KTsXO0G2Id3UwD2ln58fQ1DJu7xsepeY7s2M H/ucUa6LcL0nn3HAa6x9kGbo1106DbDVwo3VyJ2dwW3Q0L9R5OP4wzg2rtandeavhENdk5IMagfe Ox2YItaswTXbo6Al/3K1dh3ebeksZixShNBFks4c5eUzHdwHU1SjqoI7mjcv3N2gZOnm3b2u/GSF HTynyQbehP9r6GsaPMWis0L7iwk+XwhSx2LE1AVxv8Rk5Pihg+g+EpuoHtQ2TS9x9o0o9oOpE9Jh wZG7SMA0j0GMS0zbaRL/UJScIINZc+18ofLx/d33SdNDWKBWY8o9PeU1VlnpDsogzCtLkykPAgMB AAGjggFqMIIBZjASBgNVHRMBAf8ECDAGAQH/AgEMMB0GA1UdDgQWBBS5CcqcHtvTbDprru1U8VuT BjUuXjCB4QYDVR0jBIHZMIHWgBS5CcqcHtvTbDprru1U8VuTBjUuXqGBsqSBrzCBrDELMAkGA1UE BhMCRVUxQzBBBgNVBAcTOk1hZHJpZCAoc2VlIGN1cnJlbnQgYWRkcmVzcyBhdCB3d3cuY2FtZXJm aXJtYS5jb20vYWRkcmVzcykxEjAQBgNVBAUTCUE4Mjc0MzI4NzEbMBkGA1UEChMSQUMgQ2FtZXJm aXJtYSBTLkEuMScwJQYDVQQDEx5HbG9iYWwgQ2hhbWJlcnNpZ24gUm9vdCAtIDIwMDiCCQDJzdPp 1X0jzjAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRVHSAAMCowKAYIKwYBBQUHAgEWHGh0 dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20wDQYJKoZIhvcNAQEFBQADggIBAICIf3DekijZBZRG /5BXqfEv3xoNa/p8DhxJJHkn2EaqbylZUohwEurdPfWbU1Rv4WCiqAm57OtZfMY18dwY6fFn5a+6 ReAJ3spED8IXDneRRXozX1+WLGiLwUePmJs9wOzL9dWCkoQ10b42OFZyMVtHLaoXpGNR6woBrX/s dZ7LoR/xfxKxueRkf2fWIyr0uDldmOghp+G9PUIadJpwr2hsUF1Jz//7Dl3mLEfXgTpZALVza2Mg 9jFFCDkO9HB+QHBaP9BrQql0PSgvAm11cpUJjUhjxsYjV5KTXjXBjfkK9yydYhz2rXzdpjEetrHH foUm+qRqtdpjMNHvkzeyZi99Bffnt0uYlDXA2TopwZ2yUDMdSqlapskD7+3056huirRXhOukP9Du qqqHW2Pok+JrqNS4cnhrG+055F3Lm6qH1U9OAP7Zap88MQ8oAgF9mOinsKJknnn4SPIVqczmyETr P3iZ8ntxPjzxmKfFGBI/5rsoM0LpRQp8bfKGeS/Fghl9CYl8slR2iK7ewfPM4W7bMdaTrpmg7yVq c5iJWzouE4gev8CSlDQb4ye3ix5vQv/n6TebUB0tovkC7stYWDpxvGjjqsGvHCgfotwjZT+B6q6Z 09gwzxMNTxXJhLynSC34MCN32EZLeW32jO06f2ARePTpm67VVMB0gNELQp/B -----END CERTIFICATE----- Go Daddy Root Certificate Authority - G2 ======================================== -----BEGIN CERTIFICATE----- MIIDxTCCAq2gAwIBAgIBADANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMxEDAOBgNVBAgT B0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoTEUdvRGFkZHkuY29tLCBJbmMu MTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5 MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgYMxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6 b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjExMC8G A1UEAxMoR28gRGFkZHkgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZI hvcNAQEBBQADggEPADCCAQoCggEBAL9xYgjx+lk09xvJGKP3gElY6SKDE6bFIEMBO4Tx5oVJnyfq 9oQbTqC023CYxzIBsQU+B07u9PpPL1kwIuerGVZr4oAH/PMWdYA5UXvl+TW2dE6pjYIT5LY/qQOD +qK+ihVqf94Lw7YZFAXK6sOoBJQ7RnwyDfMAZiLIjWltNowRGLfTshxgtDj6AozO091GB94KPutd fMh8+7ArU6SSYmlRJQVhGkSBjCypQ5Yj36w6gZoOKcUcqeldHraenjAKOc7xiID7S13MMuyFYkMl NAJWJwGRtDtwKj9useiciAF9n9T521NtYJ2/LOdYq7hfRvzOxBsDPAnrSTFcaUaz4EcCAwEAAaNC MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFDqahQcQZyi27/a9 BUFuIMGU2g/eMA0GCSqGSIb3DQEBCwUAA4IBAQCZ21151fmXWWcDYfF+OwYxdS2hII5PZYe096ac vNjpL9DbWu7PdIxztDhC2gV7+AJ1uP2lsdeu9tfeE8tTEH6KRtGX+rcuKxGrkLAngPnon1rpN5+r 5N9ss4UXnT3ZJE95kTXWXwTrgIOrmgIttRD02JDHBHNA7XIloKmf7J6raBKZV8aPEjoJpL1E/QYV N8Gb5DKj7Tjo2GTzLH4U/ALqn83/B2gX2yKQOC16jdFU8WnjXzPKej17CuPKf1855eJ1usV2GDPO LPAvTK33sefOT6jEm0pUBsV/fdUID+Ic/n4XuKxe9tQWskMJDE32p2u0mYRlynqI4uJEvlz36hz1 -----END CERTIFICATE----- Starfield Root Certificate Authority - G2 ========================================= -----BEGIN CERTIFICATE----- MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMxEDAOBgNVBAgT B0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoTHFN0YXJmaWVsZCBUZWNobm9s b2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVsZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0 eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgY8xCzAJBgNVBAYTAlVTMRAw DgYDVQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQg VGVjaG5vbG9naWVzLCBJbmMuMTIwMAYDVQQDEylTdGFyZmllbGQgUm9vdCBDZXJ0aWZpY2F0ZSBB dXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL3twQP89o/8ArFv W59I2Z154qK3A2FWGMNHttfKPTUuiUP3oWmb3ooa/RMgnLRJdzIpVv257IzdIvpy3Cdhl+72WoTs bhm5iSzchFvVdPtrX8WJpRBSiUZV9Lh1HOZ/5FSuS/hVclcCGfgXcVnrHigHdMWdSL5stPSksPNk N3mSwOxGXn/hbVNMYq/NHwtjuzqd+/x5AJhhdM8mgkBj87JyahkNmcrUDnXMN/uLicFZ8WJ/X7Nf ZTD4p7dNdloedl40wOiWVpmKs/B/pM293DIxfJHP4F8R+GuqSVzRmZTRouNjWwl2tVZi4Ut0HZbU JtQIBFnQmA4O5t78w+wfkPECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC AQYwHQYDVR0OBBYEFHwMMh+n2TB/xH1oo2Kooc6rB1snMA0GCSqGSIb3DQEBCwUAA4IBAQARWfol TwNvlJk7mh+ChTnUdgWUXuEok21iXQnCoKjUsHU48TRqneSfioYmUeYs0cYtbpUgSpIB7LiKZ3sx 4mcujJUDJi5DnUox9g61DLu34jd/IroAow57UvtruzvE03lRTs2Q9GcHGcg8RnoNAX3FWOdt5oUw F5okxBDgBPfg8n/Uqgr/Qh037ZTlZFkSIHc40zI+OIF1lnP6aI+xy84fxez6nH7PfrHxBy22/L/K pL/QlwVKvOoYKAKQvVR4CSFx09F9HdkWsKlhPdAKACL8x3vLCWRFCztAgfd9fDL1mMpYjn0q7pBZ c2T5NnReJaH1ZgUufzkVqSr7UIuOhWn0 -----END CERTIFICATE----- Starfield Services Root Certificate Authority - G2 ================================================== -----BEGIN CERTIFICATE----- MIID7zCCAtegAwIBAgIBADANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UEBhMCVVMxEDAOBgNVBAgT B0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoTHFN0YXJmaWVsZCBUZWNobm9s b2dpZXMsIEluYy4xOzA5BgNVBAMTMlN0YXJmaWVsZCBTZXJ2aWNlcyBSb290IENlcnRpZmljYXRl IEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgZgxCzAJBgNV BAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxT dGFyZmllbGQgVGVjaG5vbG9naWVzLCBJbmMuMTswOQYDVQQDEzJTdGFyZmllbGQgU2VydmljZXMg Um9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC AQoCggEBANUMOsQq+U7i9b4Zl1+OiFOxHz/Lz58gE20pOsgPfTz3a3Y4Y9k2YKibXlwAgLIvWX/2 h/klQ4bnaRtSmpDhcePYLQ1Ob/bISdm28xpWriu2dBTrz/sm4xq6HZYuajtYlIlHVv8loJNwU4Pa hHQUw2eeBGg6345AWh1KTs9DkTvnVtYAcMtS7nt9rjrnvDH5RfbCYM8TWQIrgMw0R9+53pBlbQLP LJGmpufehRhJfGZOozptqbXuNC66DQO4M99H67FrjSXZm86B0UVGMpZwh94CDklDhbZsc7tk6mFB rMnUVN+HL8cisibMn1lUaJ/8viovxFUcdUBgF4UCVTmLfwUCAwEAAaNCMEAwDwYDVR0TAQH/BAUw AwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJxfAN+qAdcwKziIorhtSpzyEZGDMA0GCSqG SIb3DQEBCwUAA4IBAQBLNqaEd2ndOxmfZyMIbw5hyf2E3F/YNoHN2BtBLZ9g3ccaaNnRbobhiCPP E95Dz+I0swSdHynVv/heyNXBve6SbzJ08pGCL72CQnqtKrcgfU28elUSwhXqvfdqlS5sdJ/PHLTy xQGjhdByPq1zqwubdQxtRbeOlKyWN7Wg0I8VRw7j6IPdj/3vQQF3zCepYoUz8jcI73HPdwbeyBkd iEDPfUYd/x7H4c7/I9vG+o1VTqkC50cRRj70/b17KSa7qWFiNyi2LSr2EIZkyXCn0q23KXB56jza YyWf/Wi3MOxw+3WKt21gZ7IeyLnp2KhvAotnDU0mV3HaIPzBSlCNsSi6 -----END CERTIFICATE----- AffirmTrust Commercial ====================== -----BEGIN CERTIFICATE----- MIIDTDCCAjSgAwIBAgIId3cGJyapsXwwDQYJKoZIhvcNAQELBQAwRDELMAkGA1UEBhMCVVMxFDAS BgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBDb21tZXJjaWFsMB4XDTEw MDEyOTE0MDYwNloXDTMwMTIzMTE0MDYwNlowRDELMAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmly bVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBDb21tZXJjaWFsMIIBIjANBgkqhkiG9w0BAQEF AAOCAQ8AMIIBCgKCAQEA9htPZwcroRX1BiLLHwGy43NFBkRJLLtJJRTWzsO3qyxPxkEylFf6Eqdb DuKPHx6GGaeqtS25Xw2Kwq+FNXkyLbscYjfysVtKPcrNcV/pQr6U6Mje+SJIZMblq8Yrba0F8PrV C8+a5fBQpIs7R6UjW3p6+DM/uO+Zl+MgwdYoic+U+7lF7eNAFxHUdPALMeIrJmqbTFeurCA+ukV6 BfO9m2kVrn1OIGPENXY6BwLJN/3HR+7o8XYdcxXyl6S1yHp52UKqK39c/s4mT6NmgTWvRLpUHhww MmWd5jyTXlBOeuM61G7MGvv50jeuJCqrVwMiKA1JdX+3KNp1v47j3A55MQIDAQABo0IwQDAdBgNV HQ4EFgQUnZPGU4teyq8/nx4P5ZmVvCT2lI8wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC AQYwDQYJKoZIhvcNAQELBQADggEBAFis9AQOzcAN/wr91LoWXym9e2iZWEnStB03TX8nfUYGXUPG hi4+c7ImfU+TqbbEKpqrIZcUsd6M06uJFdhrJNTxFq7YpFzUf1GO7RgBsZNjvbz4YYCanrHOQnDi qX0GJX0nof5v7LMeJNrjS1UaADs1tDvZ110w/YETifLCBivtZ8SOyUOyXGsViQK8YvxO8rUzqrJv 0wqiUOP2O+guRMLbZjipM1ZI8W0bM40NjD9gN53Tym1+NH4Nn3J2ixufcv1SNUFFApYvHLKac0kh sUlHRUe072o0EclNmsxZt9YCnlpOZbWUrhvfKbAW8b8Angc6F2S1BLUjIZkKlTuXfO8= -----END CERTIFICATE----- AffirmTrust Networking ====================== -----BEGIN CERTIFICATE----- MIIDTDCCAjSgAwIBAgIIfE8EORzUmS0wDQYJKoZIhvcNAQEFBQAwRDELMAkGA1UEBhMCVVMxFDAS BgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBOZXR3b3JraW5nMB4XDTEw MDEyOTE0MDgyNFoXDTMwMTIzMTE0MDgyNFowRDELMAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmly bVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBOZXR3b3JraW5nMIIBIjANBgkqhkiG9w0BAQEF AAOCAQ8AMIIBCgKCAQEAtITMMxcua5Rsa2FSoOujz3mUTOWUgJnLVWREZY9nZOIG41w3SfYvm4SE Hi3yYJ0wTsyEheIszx6e/jarM3c1RNg1lho9Nuh6DtjVR6FqaYvZ/Ls6rnla1fTWcbuakCNrmreI dIcMHl+5ni36q1Mr3Lt2PpNMCAiMHqIjHNRqrSK6mQEubWXLviRmVSRLQESxG9fhwoXA3hA/Pe24 /PHxI1Pcv2WXb9n5QHGNfb2V1M6+oF4nI979ptAmDgAp6zxG8D1gvz9Q0twmQVGeFDdCBKNwV6gb h+0t+nvujArjqWaJGctB+d1ENmHP4ndGyH329JKBNv3bNPFyfvMMFr20FQIDAQABo0IwQDAdBgNV HQ4EFgQUBx/S55zawm6iQLSwelAQUHTEyL0wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC AQYwDQYJKoZIhvcNAQEFBQADggEBAIlXshZ6qML91tmbmzTCnLQyFE2npN/svqe++EPbkTfOtDIu UFUaNU52Q3Eg75N3ThVwLofDwR1t3Mu1J9QsVtFSUzpE0nPIxBsFZVpikpzuQY0x2+c06lkh1QF6 12S4ZDnNye2v7UsDSKegmQGA3GWjNq5lWUhPgkvIZfFXHeVZLgo/bNjR9eUJtGxUAArgFU2HdW23 WJZa3W3SAKD0m0i+wzekujbgfIeFlxoVot4uolu9rxj5kFDNcFn4J2dHy8egBzp90SxdbBk6ZrV9 /ZFvgrG+CJPbFEfxojfHRZ48x3evZKiT3/Zpg4Jg8klCNO1aAFSFHBY2kgxc+qatv9s= -----END CERTIFICATE----- AffirmTrust Premium =================== -----BEGIN CERTIFICATE----- MIIFRjCCAy6gAwIBAgIIbYwURrGmCu4wDQYJKoZIhvcNAQEMBQAwQTELMAkGA1UEBhMCVVMxFDAS BgNVBAoMC0FmZmlybVRydXN0MRwwGgYDVQQDDBNBZmZpcm1UcnVzdCBQcmVtaXVtMB4XDTEwMDEy OTE0MTAzNloXDTQwMTIzMTE0MTAzNlowQTELMAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRy dXN0MRwwGgYDVQQDDBNBZmZpcm1UcnVzdCBQcmVtaXVtMIICIjANBgkqhkiG9w0BAQEFAAOCAg8A MIICCgKCAgEAxBLfqV/+Qd3d9Z+K4/as4Tx4mrzY8H96oDMq3I0gW64tb+eT2TZwamjPjlGjhVtn BKAQJG9dKILBl1fYSCkTtuG+kU3fhQxTGJoeJKJPj/CihQvL9Cl/0qRY7iZNyaqoe5rZ+jjeRFcV 5fiMyNlI4g0WJx0eyIOFJbe6qlVBzAMiSy2RjYvmia9mx+n/K+k8rNrSs8PhaJyJ+HoAVt70VZVs +7pk3WKL3wt3MutizCaam7uqYoNMtAZ6MMgpv+0GTZe5HMQxK9VfvFMSF5yZVylmd2EhMQcuJUmd GPLu8ytxjLW6OQdJd/zvLpKQBY0tL3d770O/Nbua2Plzpyzy0FfuKE4mX4+QaAkvuPjcBukumj5R p9EixAqnOEhss/n/fauGV+O61oV4d7pD6kh/9ti+I20ev9E2bFhc8e6kGVQa9QPSdubhjL08s9NI S+LI+H+SqHZGnEJlPqQewQcDWkYtuJfzt9WyVSHvutxMAJf7FJUnM7/oQ0dG0giZFmA7mn7S5u04 6uwBHjxIVkkJx0w3AJ6IDsBz4W9m6XJHMD4Q5QsDyZpCAGzFlH5hxIrff4IaC1nEWTJ3s7xgaVY5 /bQGeyzWZDbZvUjthB9+pSKPKrhC9IK31FOQeE4tGv2Bb0TXOwF0lkLgAOIua+rF7nKsu7/+6qqo +Nz2snmKtmcCAwEAAaNCMEAwHQYDVR0OBBYEFJ3AZ6YMItkm9UWrpmVSESfYRaxjMA8GA1UdEwEB /wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBDAUAA4ICAQCzV00QYk465KzquByv MiPIs0laUZx2KI15qldGF9X1Uva3ROgIRL8YhNILgM3FEv0AVQVhh0HctSSePMTYyPtwni94loMg Nt58D2kTiKV1NpgIpsbfrM7jWNa3Pt668+s0QNiigfV4Py/VpfzZotReBA4Xrf5B8OWycvpEgjNC 6C1Y91aMYj+6QrCcDFx+LmUmXFNPALJ4fqENmS2NuB2OosSw/WDQMKSOyARiqcTtNd56l+0OOF6S L5Nwpamcb6d9Ex1+xghIsV5n61EIJenmJWtSKZGc0jlzCFfemQa0W50QBuHCAKi4HEoCChTQwUHK +4w1IX2COPKpVJEZNZOUbWo6xbLQu4mGk+ibyQ86p3q4ofB4Rvr8Ny/lioTz3/4E2aFooC8k4gmV BtWVyuEklut89pMFu+1z6S3RdTnX5yTb2E5fQ4+e0BQ5v1VwSJlXMbSc7kqYA5YwH2AG7hsj/oFg IxpHYoWlzBk0gG+zrBrjn/B7SK3VAdlntqlyk+otZrWyuOQ9PLLvTIzq6we/qzWaVYa8GKa1qF60 g2xraUDTn9zxw2lrueFtCfTxqlB2Cnp9ehehVZZCmTEJ3WARjQUwfuaORtGdFNrHF+QFlozEJLUb zxQHskD4o55BhrwE0GuWyCqANP2/7waj3VjFhT0+j/6eKeC2uAloGRwYQw== -----END CERTIFICATE----- AffirmTrust Premium ECC ======================= -----BEGIN CERTIFICATE----- MIIB/jCCAYWgAwIBAgIIdJclisc/elQwCgYIKoZIzj0EAwMwRTELMAkGA1UEBhMCVVMxFDASBgNV BAoMC0FmZmlybVRydXN0MSAwHgYDVQQDDBdBZmZpcm1UcnVzdCBQcmVtaXVtIEVDQzAeFw0xMDAx MjkxNDIwMjRaFw00MDEyMzExNDIwMjRaMEUxCzAJBgNVBAYTAlVTMRQwEgYDVQQKDAtBZmZpcm1U cnVzdDEgMB4GA1UEAwwXQWZmaXJtVHJ1c3QgUHJlbWl1bSBFQ0MwdjAQBgcqhkjOPQIBBgUrgQQA IgNiAAQNMF4bFZ0D0KF5Nbc6PJJ6yhUczWLznCZcBz3lVPqj1swS6vQUX+iOGasvLkjmrBhDeKzQ N8O9ss0s5kfiGuZjuD0uL3jET9v0D6RoTFVya5UdThhClXjMNzyR4ptlKymjQjBAMB0GA1UdDgQW BBSaryl6wBE1NSZRMADDav5A1a7WPDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAK BggqhkjOPQQDAwNnADBkAjAXCfOHiFBar8jAQr9HX/VsaobgxCd05DhT1wV/GzTjxi+zygk8N53X 57hG8f2h4nECMEJZh0PUUd+60wkyWs6Iflc9nF9Ca/UHLbXwgpP5WW+uZPpY5Yse42O+tYHNbwKM eQ== -----END CERTIFICATE----- Certum Trusted Network CA ========================= -----BEGIN CERTIFICATE----- MIIDuzCCAqOgAwIBAgIDBETAMA0GCSqGSIb3DQEBBQUAMH4xCzAJBgNVBAYTAlBMMSIwIAYDVQQK ExlVbml6ZXRvIFRlY2hub2xvZ2llcyBTLkEuMScwJQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlv biBBdXRob3JpdHkxIjAgBgNVBAMTGUNlcnR1bSBUcnVzdGVkIE5ldHdvcmsgQ0EwHhcNMDgxMDIy MTIwNzM3WhcNMjkxMjMxMTIwNzM3WjB+MQswCQYDVQQGEwJQTDEiMCAGA1UEChMZVW5pemV0byBU ZWNobm9sb2dpZXMgUy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRpZmljYXRpb24gQXV0aG9yaXR5 MSIwIAYDVQQDExlDZXJ0dW0gVHJ1c3RlZCBOZXR3b3JrIENBMIIBIjANBgkqhkiG9w0BAQEFAAOC AQ8AMIIBCgKCAQEA4/t9o3K6wvDJFIf1awFO4W5AB7ptJ11/91sts1rHUV+rpDKmYYe2bg+G0jAC l/jXaVehGDldamR5xgFZrDwxSjh80gTSSyjoIF87B6LMTXPb865Px1bVWqeWifrzq2jUI4ZZJ88J J7ysbnKDHDBy3+Ci6dLhdHUZvSqeexVUBBvXQzmtVSjF4hq79MDkrjhJM8x2hZ85RdKknvISjFH4 fOQtf/WsX+sWn7Et0brMkUJ3TCXJkDhv2/DM+44el1k+1WBO5gUo7Ul5E0u6SNsv+XLTOcr+H9g0 cvW0QM8xAcPs3hEtF10fuFDRXhmnad4HMyjKUJX5p1TLVIZQRan5SQIDAQABo0IwQDAPBgNVHRMB Af8EBTADAQH/MB0GA1UdDgQWBBQIds3LB/8k9sXN7buQvOKEN0Z19zAOBgNVHQ8BAf8EBAMCAQYw DQYJKoZIhvcNAQEFBQADggEBAKaorSLOAT2mo/9i0Eidi15ysHhE49wcrwn9I0j6vSrEuVUEtRCj jSfeC4Jj0O7eDDd5QVsisrCaQVymcODU0HfLI9MA4GxWL+FpDQ3Zqr8hgVDZBqWo/5U30Kr+4rP1 mS1FhIrlQgnXdAIv94nYmem8J9RHjboNRhx3zxSkHLmkMcScKHQDNP8zGSal6Q10tz6XxnboJ5aj Zt3hrvJBW8qYVoNzcOSGGtIxQbovvi0TWnZvTuhOgQ4/WwMioBK+ZlgRSssDxLQqKi2WF+A5VLxI 03YnnZotBqbJ7DnSq9ufmgsnAjUpsUCV5/nonFWIGUbWtzT1fs45mtk48VH3Tyw= -----END CERTIFICATE----- Certinomis - Autorité Racine ============================= -----BEGIN CERTIFICATE----- MIIFnDCCA4SgAwIBAgIBATANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJGUjETMBEGA1UEChMK Q2VydGlub21pczEXMBUGA1UECxMOMDAwMiA0MzM5OTg5MDMxJjAkBgNVBAMMHUNlcnRpbm9taXMg LSBBdXRvcml0w6kgUmFjaW5lMB4XDTA4MDkxNzA4Mjg1OVoXDTI4MDkxNzA4Mjg1OVowYzELMAkG A1UEBhMCRlIxEzARBgNVBAoTCkNlcnRpbm9taXMxFzAVBgNVBAsTDjAwMDIgNDMzOTk4OTAzMSYw JAYDVQQDDB1DZXJ0aW5vbWlzIC0gQXV0b3JpdMOpIFJhY2luZTCCAiIwDQYJKoZIhvcNAQEBBQAD ggIPADCCAgoCggIBAJ2Fn4bT46/HsmtuM+Cet0I0VZ35gb5j2CN2DpdUzZlMGvE5x4jYF1AMnmHa wE5V3udauHpOd4cN5bjr+p5eex7Ezyh0x5P1FMYiKAT5kcOrJ3NqDi5N8y4oH3DfVS9O7cdxbwly Lu3VMpfQ8Vh30WC8Tl7bmoT2R2FFK/ZQpn9qcSdIhDWerP5pqZ56XjUl+rSnSTV3lqc2W+HN3yNw 2F1MpQiD8aYkOBOo7C+ooWfHpi2GR+6K/OybDnT0K0kCe5B1jPyZOQE51kqJ5Z52qz6WKDgmi92N jMD2AR5vpTESOH2VwnHu7XSu5DaiQ3XV8QCb4uTXzEIDS3h65X27uK4uIJPT5GHfceF2Z5c/tt9q c1pkIuVC28+BA5PY9OMQ4HL2AHCs8MF6DwV/zzRpRbWT5BnbUhYjBYkOjUjkJW+zeL9i9Qf6lSTC lrLooyPCXQP8w9PlfMl1I9f09bze5N/NgL+RiH2nE7Q5uiy6vdFrzPOlKO1Enn1So2+WLhl+HPNb xxaOu2B9d2ZHVIIAEWBsMsGoOBvrbpgT1u449fCfDu/+MYHB0iSVL1N6aaLwD4ZFjliCK0wi1F6g 530mJ0jfJUaNSih8hp75mxpZuWW/Bd22Ql095gBIgl4g9xGC3srYn+Y3RyYe63j3YcNBZFgCQfna 4NH4+ej9Uji29YnfAgMBAAGjWzBZMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0G A1UdDgQWBBQNjLZh2kS40RR9w759XkjwzspqsDAXBgNVHSAEEDAOMAwGCiqBegFWAgIAAQEwDQYJ KoZIhvcNAQEFBQADggIBACQ+YAZ+He86PtvqrxyaLAEL9MW12Ukx9F1BjYkMTv9sov3/4gbIOZ/x WqndIlgVqIrTseYyCYIDbNc/CMf4uboAbbnW/FIyXaR/pDGUu7ZMOH8oMDX/nyNTt7buFHAAQCva R6s0fl6nVjBhK4tDrP22iCj1a7Y+YEq6QpA0Z43q619FVDsXrIvkxmUP7tCMXWY5zjKn2BCXwH40 nJ+U8/aGH88bc62UeYdocMMzpXDn2NU4lG9jeeu/Cg4I58UvD0KgKxRA/yHgBcUn4YQRE7rWhh1B CxMjidPJC+iKunqjo3M3NYB9Ergzd0A4wPpeMNLytqOx1qKVl4GbUu1pTP+A5FPbVFsDbVRfsbjv JL1vnxHDx2TCDyhihWZeGnuyt++uNckZM6i4J9szVb9o4XVIRFb7zdNIu0eJOqxp9YDG5ERQL1TE qkPFMTFYvZbF6nVsmnWxTfj3l/+WFvKXTej28xH5On2KOG4Ey+HTRRWqpdEdnV1j6CTmNhTih60b WfVEm/vXd3wfAXBioSAaosUaKPQhA+4u2cGA6rnZgtZbdsLLO7XSAPCjDuGtbkD326C00EauFddE wk01+dIL8hf2rGbVJLJP0RyZwG71fet0BLj5TXcJ17TPBzAJ8bgAVtkXFhYKK4bfjwEZGuW7gmP/ vgt2Fl43N+bYdJeimUV5 -----END CERTIFICATE----- Root CA Generalitat Valenciana ============================== -----BEGIN CERTIFICATE----- MIIGizCCBXOgAwIBAgIEO0XlaDANBgkqhkiG9w0BAQUFADBoMQswCQYDVQQGEwJFUzEfMB0GA1UE ChMWR2VuZXJhbGl0YXQgVmFsZW5jaWFuYTEPMA0GA1UECxMGUEtJR1ZBMScwJQYDVQQDEx5Sb290 IENBIEdlbmVyYWxpdGF0IFZhbGVuY2lhbmEwHhcNMDEwNzA2MTYyMjQ3WhcNMjEwNzAxMTUyMjQ3 WjBoMQswCQYDVQQGEwJFUzEfMB0GA1UEChMWR2VuZXJhbGl0YXQgVmFsZW5jaWFuYTEPMA0GA1UE CxMGUEtJR1ZBMScwJQYDVQQDEx5Sb290IENBIEdlbmVyYWxpdGF0IFZhbGVuY2lhbmEwggEiMA0G CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDGKqtXETcvIorKA3Qdyu0togu8M1JAJke+WmmmO3I2 F0zo37i7L3bhQEZ0ZQKQUgi0/6iMweDHiVYQOTPvaLRfX9ptI6GJXiKjSgbwJ/BXufjpTjJ3Cj9B ZPPrZe52/lSqfR0grvPXdMIKX/UIKFIIzFVd0g/bmoGlu6GzwZTNVOAydTGRGmKy3nXiz0+J2ZGQ D0EbtFpKd71ng+CT516nDOeB0/RSrFOyA8dEJvt55cs0YFAQexvba9dHq198aMpunUEDEO5rmXte JajCq+TA81yc477OMUxkHl6AovWDfgzWyoxVjr7gvkkHD6MkQXpYHYTqWBLI4bft75PelAgxAgMB AAGjggM7MIIDNzAyBggrBgEFBQcBAQQmMCQwIgYIKwYBBQUHMAGGFmh0dHA6Ly9vY3NwLnBraS5n dmEuZXMwEgYDVR0TAQH/BAgwBgEB/wIBAjCCAjQGA1UdIASCAiswggInMIICIwYKKwYBBAG/VQIB ADCCAhMwggHoBggrBgEFBQcCAjCCAdoeggHWAEEAdQB0AG8AcgBpAGQAYQBkACAAZABlACAAQwBl AHIAdABpAGYAaQBjAGEAYwBpAPMAbgAgAFIAYQDtAHoAIABkAGUAIABsAGEAIABHAGUAbgBlAHIA YQBsAGkAdABhAHQAIABWAGEAbABlAG4AYwBpAGEAbgBhAC4ADQAKAEwAYQAgAEQAZQBjAGwAYQBy AGEAYwBpAPMAbgAgAGQAZQAgAFAAcgDhAGMAdABpAGMAYQBzACAAZABlACAAQwBlAHIAdABpAGYA aQBjAGEAYwBpAPMAbgAgAHEAdQBlACAAcgBpAGcAZQAgAGUAbAAgAGYAdQBuAGMAaQBvAG4AYQBt AGkAZQBuAHQAbwAgAGQAZQAgAGwAYQAgAHAAcgBlAHMAZQBuAHQAZQAgAEEAdQB0AG8AcgBpAGQA YQBkACAAZABlACAAQwBlAHIAdABpAGYAaQBjAGEAYwBpAPMAbgAgAHMAZQAgAGUAbgBjAHUAZQBu AHQAcgBhACAAZQBuACAAbABhACAAZABpAHIAZQBjAGMAaQDzAG4AIAB3AGUAYgAgAGgAdAB0AHAA OgAvAC8AdwB3AHcALgBwAGsAaQAuAGcAdgBhAC4AZQBzAC8AYwBwAHMwJQYIKwYBBQUHAgEWGWh0 dHA6Ly93d3cucGtpLmd2YS5lcy9jcHMwHQYDVR0OBBYEFHs100DSHHgZZu90ECjcPk+yeAT8MIGV BgNVHSMEgY0wgYqAFHs100DSHHgZZu90ECjcPk+yeAT8oWykajBoMQswCQYDVQQGEwJFUzEfMB0G A1UEChMWR2VuZXJhbGl0YXQgVmFsZW5jaWFuYTEPMA0GA1UECxMGUEtJR1ZBMScwJQYDVQQDEx5S b290IENBIEdlbmVyYWxpdGF0IFZhbGVuY2lhbmGCBDtF5WgwDQYJKoZIhvcNAQEFBQADggEBACRh TvW1yEICKrNcda3FbcrnlD+laJWIwVTAEGmiEi8YPyVQqHxK6sYJ2fR1xkDar1CdPaUWu20xxsdz Ckj+IHLtb8zog2EWRpABlUt9jppSCS/2bxzkoXHPjCpaF3ODR00PNvsETUlR4hTJZGH71BTg9J63 NI8KJr2XXPR5OkowGcytT6CYirQxlyric21+eLj4iIlPsSKRZEv1UN4D2+XFducTZnV+ZfsBn5OH iJ35Rld8TWCvmHMTI6QgkYH60GFmuH3Rr9ZvHmw96RH9qfmCIoaZM3Fa6hlXPZHNqcCjbgcTpsnt +GijnsNacgmHKNHEc8RzGF9QdRYxn7fofMM= -----END CERTIFICATE----- A-Trust-nQual-03 ================ -----BEGIN CERTIFICATE----- MIIDzzCCAregAwIBAgIDAWweMA0GCSqGSIb3DQEBBQUAMIGNMQswCQYDVQQGEwJBVDFIMEYGA1UE Cgw/QS1UcnVzdCBHZXMuIGYuIFNpY2hlcmhlaXRzc3lzdGVtZSBpbSBlbGVrdHIuIERhdGVudmVy a2VociBHbWJIMRkwFwYDVQQLDBBBLVRydXN0LW5RdWFsLTAzMRkwFwYDVQQDDBBBLVRydXN0LW5R dWFsLTAzMB4XDTA1MDgxNzIyMDAwMFoXDTE1MDgxNzIyMDAwMFowgY0xCzAJBgNVBAYTAkFUMUgw RgYDVQQKDD9BLVRydXN0IEdlcy4gZi4gU2ljaGVyaGVpdHNzeXN0ZW1lIGltIGVsZWt0ci4gRGF0 ZW52ZXJrZWhyIEdtYkgxGTAXBgNVBAsMEEEtVHJ1c3QtblF1YWwtMDMxGTAXBgNVBAMMEEEtVHJ1 c3QtblF1YWwtMDMwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCtPWFuA/OQO8BBC4SA zewqo51ru27CQoT3URThoKgtUaNR8t4j8DRE/5TrzAUjlUC5B3ilJfYKvUWG6Nm9wASOhURh73+n yfrBJcyFLGM/BWBzSQXgYHiVEEvc+RFZznF/QJuKqiTfC0Li21a8StKlDJu3Qz7dg9MmEALP6iPE SU7l0+m0iKsMrmKS1GWH2WrX9IWf5DMiJaXlyDO6w8dB3F/GaswADm0yqLaHNgBid5seHzTLkDx4 iHQF63n1k3Flyp3HaxgtPVxO59X4PzF9j4fsCiIvI+n+u33J4PTs63zEsMMtYrWacdaxaujs2e3V cuy+VwHOBVWf3tFgiBCzAgMBAAGjNjA0MA8GA1UdEwEB/wQFMAMBAf8wEQYDVR0OBAoECERqlWdV eRFPMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAVdRU0VlIXLOThaq/Yy/kgM40 ozRiPvbY7meIMQQDbwvUB/tOdQ/TLtPAF8fGKOwGDREkDg6lXb+MshOWcdzUzg4NCmgybLlBMRmr sQd7TZjTXLDR8KdCoLXEjq/+8T/0709GAHbrAvv5ndJAlseIOrifEXnzgGWovR/TeIGgUUw3tKZd JXDRZslo+S4RFGjxVJgIrCaSD96JntT6s3kr0qN51OyLrIdTaEJMUVF0HhsnLuP1Hyl0Te2v9+GS mYHovjrHF1D2t8b8m7CKa9aIA5GPBnc6hQLdmNVDeD/GMBWsm2vLV7eJUYs66MmEDNuxUCAKGkq6 ahq97BvIxYSazQ== -----END CERTIFICATE----- TWCA Root Certification Authority ================================= -----BEGIN CERTIFICATE----- MIIDezCCAmOgAwIBAgIBATANBgkqhkiG9w0BAQUFADBfMQswCQYDVQQGEwJUVzESMBAGA1UECgwJ VEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NBIFJvb3QgQ2VydGlmaWNh dGlvbiBBdXRob3JpdHkwHhcNMDgwODI4MDcyNDMzWhcNMzAxMjMxMTU1OTU5WjBfMQswCQYDVQQG EwJUVzESMBAGA1UECgwJVEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NB IFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEK AoIBAQCwfnK4pAOU5qfeCTiRShFAh6d8WWQUe7UREN3+v9XAu1bihSX0NXIP+FPQQeFEAcK0HMMx QhZHhTMidrIKbw/lJVBPhYa+v5guEGcevhEFhgWQxFnQfHgQsIBct+HHK3XLfJ+utdGdIzdjp9xC oi2SBBtQwXu4PhvJVgSLL1KbralW6cH/ralYhzC2gfeXRfwZVzsrb+RH9JlF/h3x+JejiB03HFyP 4HYlmlD4oFT/RJB2I9IyxsOrBr/8+7/zrX2SYgJbKdM1o5OaQ2RgXbL6Mv87BK9NQGr5x+PvI/1r y+UPizgN7gr8/g+YnzAx3WxSZfmLgb4i4RxYA7qRG4kHAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIB BjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqOFsmjd6LWvJPelSDGRjjCDWmujANBgkqhkiG 9w0BAQUFAAOCAQEAPNV3PdrfibqHDAhUaiBQkr6wQT25JmSDCi/oQMCXKCeCMErJk/9q56YAf4lC mtYR5VPOL8zy2gXE/uJQxDqGfczafhAJO5I1KlOy/usrBdlsXebQ79NqZp4VKIV66IIArB6nCWlW QtNoURi+VJq/REG6Sb4gumlc7rh3zc5sH62Dlhh9DrUUOYTxKOkto557HnpyWoOzeW/vtPzQCqVY T0bf+215WfKEIlKuD8z7fDvnaspHYcN6+NOSBB+4IIThNlQWx0DeO4pz3N/GCUzf7Nr/1FNCocny Yh0igzyXxfkZYiesZSLX0zzG5Y6yU8xJzrww/nsOM5D77dIUkR8Hrw== -----END CERTIFICATE----- Security Communication RootCA2 ============================== -----BEGIN CERTIFICATE----- MIIDdzCCAl+gAwIBAgIBADANBgkqhkiG9w0BAQsFADBdMQswCQYDVQQGEwJKUDElMCMGA1UEChMc U0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UECxMeU2VjdXJpdHkgQ29tbXVuaWNh dGlvbiBSb290Q0EyMB4XDTA5MDUyOTA1MDAzOVoXDTI5MDUyOTA1MDAzOVowXTELMAkGA1UEBhMC SlAxJTAjBgNVBAoTHFNFQ09NIFRydXN0IFN5c3RlbXMgQ08uLExURC4xJzAlBgNVBAsTHlNlY3Vy aXR5IENvbW11bmljYXRpb24gUm9vdENBMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB ANAVOVKxUrO6xVmCxF1SrjpDZYBLx/KWvNs2l9amZIyoXvDjChz335c9S672XewhtUGrzbl+dp++ +T42NKA7wfYxEUV0kz1XgMX5iZnK5atq1LXaQZAQwdbWQonCv/Q4EpVMVAX3NuRFg3sUZdbcDE3R 3n4MqzvEFb46VqZab3ZpUql6ucjrappdUtAtCms1FgkQhNBqyjoGADdH5H5XTz+L62e4iKrFvlNV spHEfbmwhRkGeC7bYRr6hfVKkaHnFtWOojnflLhwHyg/i/xAXmODPIMqGplrz95Zajv8bxbXH/1K EOtOghY6rCcMU/Gt1SSwawNQwS08Ft1ENCcadfsCAwEAAaNCMEAwHQYDVR0OBBYEFAqFqXdlBZh8 QIH4D5csOPEK7DzPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEB CwUAA4IBAQBMOqNErLlFsceTfsgLCkLfZOoc7llsCLqJX2rKSpWeeo8HxdpFcoJxDjrSzG+ntKEj u/Ykn8sX/oymzsLS28yN/HH8AynBbF0zX2S2ZTuJbxh2ePXcokgfGT+Ok+vx+hfuzU7jBBJV1uXk 3fs+BXziHV7Gp7yXT2g69ekuCkO2r1dcYmh8t/2jioSgrGK+KwmHNPBqAbubKVY8/gA3zyNs8U6q tnRGEmyR7jTV7JqR50S+kDFy1UkC9gLl9B/rfNmWVan/7Ir5mUf/NVoCqgTLiluHcSmRvaS0eg29 mvVXIwAHIRc/SjnRBUkLp7Y3gaVdjKozXoEofKd9J+sAro03 -----END CERTIFICATE----- EC-ACC ====== -----BEGIN CERTIFICATE----- MIIFVjCCBD6gAwIBAgIQ7is969Qh3hSoYqwE893EATANBgkqhkiG9w0BAQUFADCB8zELMAkGA1UE BhMCRVMxOzA5BgNVBAoTMkFnZW5jaWEgQ2F0YWxhbmEgZGUgQ2VydGlmaWNhY2lvIChOSUYgUS0w ODAxMTc2LUkpMSgwJgYDVQQLEx9TZXJ2ZWlzIFB1YmxpY3MgZGUgQ2VydGlmaWNhY2lvMTUwMwYD VQQLEyxWZWdldSBodHRwczovL3d3dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbCAoYykwMzE1MDMGA1UE CxMsSmVyYXJxdWlhIEVudGl0YXRzIGRlIENlcnRpZmljYWNpbyBDYXRhbGFuZXMxDzANBgNVBAMT BkVDLUFDQzAeFw0wMzAxMDcyMzAwMDBaFw0zMTAxMDcyMjU5NTlaMIHzMQswCQYDVQQGEwJFUzE7 MDkGA1UEChMyQWdlbmNpYSBDYXRhbGFuYSBkZSBDZXJ0aWZpY2FjaW8gKE5JRiBRLTA4MDExNzYt SSkxKDAmBgNVBAsTH1NlcnZlaXMgUHVibGljcyBkZSBDZXJ0aWZpY2FjaW8xNTAzBgNVBAsTLFZl Z2V1IGh0dHBzOi8vd3d3LmNhdGNlcnQubmV0L3ZlcmFycmVsIChjKTAzMTUwMwYDVQQLEyxKZXJh cnF1aWEgRW50aXRhdHMgZGUgQ2VydGlmaWNhY2lvIENhdGFsYW5lczEPMA0GA1UEAxMGRUMtQUND MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsyLHT+KXQpWIR4NA9h0X84NzJB5R85iK w5K4/0CQBXCHYMkAqbWUZRkiFRfCQ2xmRJoNBD45b6VLeqpjt4pEndljkYRm4CgPukLjbo73FCeT ae6RDqNfDrHrZqJyTxIThmV6PttPB/SnCWDaOkKZx7J/sxaVHMf5NLWUhdWZXqBIoH7nF2W4onW4 HvPlQn2v7fOKSGRdghST2MDk/7NQcvJ29rNdQlB50JQ+awwAvthrDk4q7D7SzIKiGGUzE3eeml0a E9jD2z3Il3rucO2n5nzbcc8tlGLfbdb1OL4/pYUKGbio2Al1QnDE6u/LDsg0qBIimAy4E5S2S+zw 0JDnJwIDAQABo4HjMIHgMB0GA1UdEQQWMBSBEmVjX2FjY0BjYXRjZXJ0Lm5ldDAPBgNVHRMBAf8E BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUoMOLRKo3pUW/l4Ba0fF4opvpXY0wfwYD VR0gBHgwdjB0BgsrBgEEAfV4AQMBCjBlMCwGCCsGAQUFBwIBFiBodHRwczovL3d3dy5jYXRjZXJ0 Lm5ldC92ZXJhcnJlbDA1BggrBgEFBQcCAjApGidWZWdldSBodHRwczovL3d3dy5jYXRjZXJ0Lm5l dC92ZXJhcnJlbCAwDQYJKoZIhvcNAQEFBQADggEBAKBIW4IB9k1IuDlVNZyAelOZ1Vr/sXE7zDkJ lF7W2u++AVtd0x7Y/X1PzaBB4DSTv8vihpw3kpBWHNzrKQXlxJ7HNd+KDM3FIUPpqojlNcAZQmNa Al6kSBg6hW/cnbw/nZzBh7h6YQjpdwt/cKt63dmXLGQehb+8dJahw3oS7AwaboMMPOhyRp/7SNVe l+axofjk70YllJyJ22k4vuxcDlbHZVHlUIiIv0LVKz3l+bqeLrPK9HOSAgu+TGbrIP65y7WZf+a2 E/rKS03Z7lNGBjvGTq2TWoF+bCpLagVFjPIhpDGQh2xlnJ2lYJU6Un/10asIbvPuW/mIPX64b24D 5EI= -----END CERTIFICATE----- Hellenic Academic and Research Institutions RootCA 2011 ======================================================= -----BEGIN CERTIFICATE----- MIIEMTCCAxmgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBlTELMAkGA1UEBhMCR1IxRDBCBgNVBAoT O0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgQ2VydC4gQXV0aG9y aXR5MUAwPgYDVQQDEzdIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25z IFJvb3RDQSAyMDExMB4XDTExMTIwNjEzNDk1MloXDTMxMTIwMTEzNDk1MlowgZUxCzAJBgNVBAYT AkdSMUQwQgYDVQQKEztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25z IENlcnQuIEF1dGhvcml0eTFAMD4GA1UEAxM3SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2VhcmNo IEluc3RpdHV0aW9ucyBSb290Q0EgMjAxMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB AKlTAOMupvaO+mDYLZU++CwqVE7NuYRhlFhPjz2L5EPzdYmNUeTDN9KKiE15HrcS3UN4SoqS5tdI 1Q+kOilENbgH9mgdVc04UfCMJDGFr4PJfel3r+0ae50X+bOdOFAPplp5kYCvN66m0zH7tSYJnTxa 71HFK9+WXesyHgLacEnsbgzImjeN9/E2YEsmLIKe0HjzDQ9jpFEw4fkrJxIH2Oq9GGKYsFk3fb7u 8yBRQlqD75O6aRXxYp2fmTmCobd0LovUxQt7L/DICto9eQqakxylKHJzkUOap9FNhYS5qXSPFEDH 3N6sQWRstBmbAmNtJGSPRLIl6s5ddAxjMlyNh+UCAwEAAaOBiTCBhjAPBgNVHRMBAf8EBTADAQH/ MAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQUppFC/RNhSiOeCKQp5dgTBCPuQSUwRwYDVR0eBEAwPqA8 MAWCAy5ncjAFggMuZXUwBoIELmVkdTAGggQub3JnMAWBAy5ncjAFgQMuZXUwBoEELmVkdTAGgQQu b3JnMA0GCSqGSIb3DQEBBQUAA4IBAQAf73lB4XtuP7KMhjdCSk4cNx6NZrokgclPEg8hwAOXhiVt XdMiKahsog2p6z0GW5k6x8zDmjR/qw7IThzh+uTczQ2+vyT+bOdrwg3IBp5OjWEopmr95fZi6hg8 TqBTnbI6nOulnJEWtk2C4AwFSKls9cz4y51JtPACpf1wA+2KIaWuE4ZJwzNzvoc7dIsXRSZMFpGD /md9zU1jZ/rzAxKWeAaNsWftjj++n08C9bMJL/NMh98qy5V8AcysNnq/onN694/BtZqhFLKPM58N 7yLcZnuEvUUXBj08yrl3NI/K6s8/MT7jiOOASSXIl7WdmplNsDz4SgCbZN2fOUvRJ9e4 -----END CERTIFICATE----- Actalis Authentication Root CA ============================== -----BEGIN CERTIFICATE----- MIIFuzCCA6OgAwIBAgIIVwoRl0LE48wwDQYJKoZIhvcNAQELBQAwazELMAkGA1UEBhMCSVQxDjAM BgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8wMzM1ODUyMDk2NzEnMCUGA1UE AwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290IENBMB4XDTExMDkyMjExMjIwMloXDTMwMDky MjExMjIwMlowazELMAkGA1UEBhMCSVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlz IFMucC5BLi8wMzM1ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290 IENBMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAp8bEpSmkLO/lGMWwUKNvUTufClrJ wkg4CsIcoBh/kbWHuUA/3R1oHwiD1S0eiKD4j1aPbZkCkpAW1V8IbInX4ay8IMKx4INRimlNAJZa by/ARH6jDuSRzVju3PvHHkVH3Se5CAGfpiEd9UEtL0z9KK3giq0itFZljoZUj5NDKd45RnijMCO6 zfB9E1fAXdKDa0hMxKufgFpbOr3JpyI/gCczWw63igxdBzcIy2zSekciRDXFzMwujt0q7bd9Zg1f YVEiVRvjRuPjPdA1YprbrxTIW6HMiRvhMCb8oJsfgadHHwTrozmSBp+Z07/T6k9QnBn+locePGX2 oxgkg4YQ51Q+qDp2JE+BIcXjDwL4k5RHILv+1A7TaLndxHqEguNTVHnd25zS8gebLra8Pu2Fbe8l EfKXGkJh90qX6IuxEAf6ZYGyojnP9zz/GPvG8VqLWeICrHuS0E4UT1lF9gxeKF+w6D9Fz8+vm2/7 hNN3WpVvrJSEnu68wEqPSpP4RCHiMUVhUE4Q2OM1fEwZtN4Fv6MGn8i1zeQf1xcGDXqVdFUNaBr8 EBtiZJ1t4JWgw5QHVw0U5r0F+7if5t+L4sbnfpb2U8WANFAoWPASUHEXMLrmeGO89LKtmyuy/uE5 jF66CyCU3nuDuP/jVo23Eek7jPKxwV2dpAtMK9myGPW1n0sCAwEAAaNjMGEwHQYDVR0OBBYEFFLY iDrIn3hm7YnzezhwlMkCAjbQMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUUtiIOsifeGbt ifN7OHCUyQICNtAwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQALe3KHwGCmSUyI WOYdiPcUZEim2FgKDk8TNd81HdTtBjHIgT5q1d07GjLukD0R0i70jsNjLiNmsGe+b7bAEzlgqqI0 JZN1Ut6nna0Oh4lScWoWPBkdg/iaKWW+9D+a2fDzWochcYBNy+A4mz+7+uAwTc+G02UQGRjRlwKx K3JCaKygvU5a2hi/a5iB0P2avl4VSM0RFbnAKVy06Ij3Pjaut2L9HmLecHgQHEhb2rykOLpn7VU+ Xlff1ANATIGk0k9jpwlCCRT8AKnCgHNPLsBA2RF7SOp6AsDT6ygBJlh0wcBzIm2Tlf05fbsq4/aC 4yyXX04fkZT6/iyj2HYauE2yOE+b+h1IYHkm4vP9qdCa6HCPSXrW5b0KDtst842/6+OkfcvHlXHo 2qN8xcL4dJIEG4aspCJTQLas/kx2z/uUMsA1n3Y/buWQbqCmJqK4LL7RK4X9p2jIugErsWx0Hbhz lefut8cl8ABMALJ+tguLHPPAUJ4lueAI3jZm/zel0btUZCzJJ7VLkn5l/9Mt4blOvH+kQSGQQXem OR/qnuOf0GZvBeyqdn6/axag67XH/JJULysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9 vwGYT7JZVEc+NHt4bVaTLnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg== -----END CERTIFICATE----- Trustis FPS Root CA =================== -----BEGIN CERTIFICATE----- MIIDZzCCAk+gAwIBAgIQGx+ttiD5JNM2a/fH8YygWTANBgkqhkiG9w0BAQUFADBFMQswCQYDVQQG EwJHQjEYMBYGA1UEChMPVHJ1c3RpcyBMaW1pdGVkMRwwGgYDVQQLExNUcnVzdGlzIEZQUyBSb290 IENBMB4XDTAzMTIyMzEyMTQwNloXDTI0MDEyMTExMzY1NFowRTELMAkGA1UEBhMCR0IxGDAWBgNV BAoTD1RydXN0aXMgTGltaXRlZDEcMBoGA1UECxMTVHJ1c3RpcyBGUFMgUm9vdCBDQTCCASIwDQYJ KoZIhvcNAQEBBQADggEPADCCAQoCggEBAMVQe547NdDfxIzNjpvto8A2mfRC6qc+gIMPpqdZh8mQ RUN+AOqGeSoDvT03mYlmt+WKVoaTnGhLaASMk5MCPjDSNzoiYYkchU59j9WvezX2fihHiTHcDnlk H5nSW7r+f2C/revnPDgpai/lkQtV/+xvWNUtyd5MZnGPDNcE2gfmHhjjvSkCqPoc4Vu5g6hBSLwa cY3nYuUtsuvffM/bq1rKMfFMIvMFE/eC+XN5DL7XSxzA0RU8k0Fk0ea+IxciAIleH2ulrG6nS4zt o3Lmr2NNL4XSFDWaLk6M6jKYKIahkQlBOrTh4/L68MkKokHdqeMDx4gVOxzUGpTXn2RZEm0CAwEA AaNTMFEwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBS6+nEleYtXQSUhhgtx67JkDoshZzAd BgNVHQ4EFgQUuvpxJXmLV0ElIYYLceuyZA6LIWcwDQYJKoZIhvcNAQEFBQADggEBAH5Y//01GX2c GE+esCu8jowU/yyg2kdbw++BLa8F6nRIW/M+TgfHbcWzk88iNVy2P3UnXwmWzaD+vkAMXBJV+JOC yinpXj9WV4s4NvdFGkwozZ5BuO1WTISkQMi4sKUraXAEasP41BIy+Q7DsdwyhEQsb8tGD+pmQQ9P 8Vilpg0ND2HepZ5dfWWhPBfnqFVO76DH7cZEf1T1o+CP8HxVIo8ptoGj4W1OLBuAZ+ytIJ8MYmHV l/9D7S3B2l0pKoU/rGXuhg8FjZBf3+6f9L/uHfuY5H+QK4R4EA5sSVPvFVtlRkpdr7r7OnIdzfYl iB6XzCGcKQENZetX2fNXlrtIzYE= -----END CERTIFICATE----- StartCom Certification Authority ================================ -----BEGIN CERTIFICATE----- MIIHhzCCBW+gAwIBAgIBLTANBgkqhkiG9w0BAQsFADB9MQswCQYDVQQGEwJJTDEWMBQGA1UEChMN U3RhcnRDb20gTHRkLjErMCkGA1UECxMiU2VjdXJlIERpZ2l0YWwgQ2VydGlmaWNhdGUgU2lnbmlu ZzEpMCcGA1UEAxMgU3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDYwOTE3MTk0 NjM3WhcNMzYwOTE3MTk0NjM2WjB9MQswCQYDVQQGEwJJTDEWMBQGA1UEChMNU3RhcnRDb20gTHRk LjErMCkGA1UECxMiU2VjdXJlIERpZ2l0YWwgQ2VydGlmaWNhdGUgU2lnbmluZzEpMCcGA1UEAxMg U3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAw ggIKAoICAQDBiNsJvGxGfHiflXu1M5DycmLWwTYgIiRezul38kMKogZkpMyONvg45iPwbm2xPN1y o4UcodM9tDMr0y+v/uqwQVlntsQGfQqedIXWeUyAN3rfOQVSWff0G0ZDpNKFhdLDcfN1YjS6LIp/ Ho/u7TTQEceWzVI9ujPW3U3eCztKS5/CJi/6tRYccjV3yjxd5srhJosaNnZcAdt0FCX+7bWgiA/d eMotHweXMAEtcnn6RtYTKqi5pquDSR3l8u/d5AGOGAqPY1MWhWKpDhk6zLVmpsJrdAfkK+F2PrRt 2PZE4XNiHzvEvqBTViVsUQn3qqvKv3b9bZvzndu/PWa8DFaqr5hIlTpL36dYUNk4dalb6kMMAv+Z 6+hsTXBbKWWc3apdzK8BMewM69KN6Oqce+Zu9ydmDBpI125C4z/eIT574Q1w+2OqqGwaVLRcJXrJ osmLFqa7LH4XXgVNWG4SHQHuEhANxjJ/GP/89PrNbpHoNkm+Gkhpi8KWTRoSsmkXwQqQ1vp5Iki/ untp+HDH+no32NgN0nZPV/+Qt+OR0t3vwmC3Zzrd/qqc8NSLf3Iizsafl7b4r4qgEKjZ+xjGtrVc UjyJthkqcwEKDwOzEmDyei+B26Nu/yYwl/WL3YlXtq09s68rxbd2AvCl1iuahhQqcvbjM4xdCUsT 37uMdBNSSwIDAQABo4ICEDCCAgwwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYD VR0OBBYEFE4L7xqkQFulF2mHMMo0aEPQQa7yMB8GA1UdIwQYMBaAFE4L7xqkQFulF2mHMMo0aEPQ Qa7yMIIBWgYDVR0gBIIBUTCCAU0wggFJBgsrBgEEAYG1NwEBATCCATgwLgYIKwYBBQUHAgEWImh0 dHA6Ly93d3cuc3RhcnRzc2wuY29tL3BvbGljeS5wZGYwNAYIKwYBBQUHAgEWKGh0dHA6Ly93d3cu c3RhcnRzc2wuY29tL2ludGVybWVkaWF0ZS5wZGYwgc8GCCsGAQUFBwICMIHCMCcWIFN0YXJ0IENv bW1lcmNpYWwgKFN0YXJ0Q29tKSBMdGQuMAMCAQEagZZMaW1pdGVkIExpYWJpbGl0eSwgcmVhZCB0 aGUgc2VjdGlvbiAqTGVnYWwgTGltaXRhdGlvbnMqIG9mIHRoZSBTdGFydENvbSBDZXJ0aWZpY2F0 aW9uIEF1dGhvcml0eSBQb2xpY3kgYXZhaWxhYmxlIGF0IGh0dHA6Ly93d3cuc3RhcnRzc2wuY29t L3BvbGljeS5wZGYwEQYJYIZIAYb4QgEBBAQDAgAHMDgGCWCGSAGG+EIBDQQrFilTdGFydENvbSBG cmVlIFNTTCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTANBgkqhkiG9w0BAQsFAAOCAgEAjo/n3JR5 fPGFf59Jb2vKXfuM/gTFwWLRfUKKvFO3lANmMD+x5wqnUCBVJX92ehQN6wQOQOY+2IirByeDqXWm N3PH/UvSTa0XQMhGvjt/UfzDtgUx3M2FIk5xt/JxXrAaxrqTi3iSSoX4eA+D/i+tLPfkpLst0OcN Org+zvZ49q5HJMqjNTbOx8aHmNrs++myziebiMMEofYLWWivydsQD032ZGNcpRJvkrKTlMeIFw6T tn5ii5B/q06f/ON1FE8qMt9bDeD1e5MNq6HPh+GlBEXoPBKlCcWw0bdT82AUuoVpaiF8H3VhFyAX e2w7QSlc4axa0c2Mm+tgHRns9+Ww2vl5GKVFP0lDV9LdJNUso/2RjSe15esUBppMeyG7Oq0wBhjA 2MFrLH9ZXF2RsXAiV+uKa0hK1Q8p7MZAwC+ITGgBF3f0JBlPvfrhsiAhS90a2Cl9qrjeVOwhVYBs HvUwyKMQ5bLmKhQxw4UtjJixhlpPiVktucf3HMiKf8CdBUrmQk9io20ppB+Fq9vlgcitKj1MXVuE JnHEhV5xJMqlG2zYYdMa4FTbzrqpMrUi9nNBCV24F10OD5mQ1kfabwo6YigUZ4LZ8dCAWZvLMdib D4x3TrVoivJs9iQOLWxwxXPR3hTQcY+203sC9uO41Alua551hDnmfyWl8kgAwKQB2j8= -----END CERTIFICATE----- StartCom Certification Authority G2 =================================== -----BEGIN CERTIFICATE----- MIIFYzCCA0ugAwIBAgIBOzANBgkqhkiG9w0BAQsFADBTMQswCQYDVQQGEwJJTDEWMBQGA1UEChMN U3RhcnRDb20gTHRkLjEsMCoGA1UEAxMjU3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkg RzIwHhcNMTAwMTAxMDEwMDAxWhcNMzkxMjMxMjM1OTAxWjBTMQswCQYDVQQGEwJJTDEWMBQGA1UE ChMNU3RhcnRDb20gTHRkLjEsMCoGA1UEAxMjU3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3Jp dHkgRzIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC2iTZbB7cgNr2Cu+EWIAOVeq8O o1XJJZlKxdBWQYeQTSFgpBSHO839sj60ZwNq7eEPS8CRhXBF4EKe3ikj1AENoBB5uNsDvfOpL9HG 4A/LnooUCri99lZi8cVytjIl2bLzvWXFDSxu1ZJvGIsAQRSCb0AgJnooD/Uefyf3lLE3PbfHkffi Aez9lInhzG7TNtYKGXmu1zSCZf98Qru23QumNK9LYP5/Q0kGi4xDuFby2X8hQxfqp0iVAXV16iul Q5XqFYSdCI0mblWbq9zSOdIxHWDirMxWRST1HFSr7obdljKF+ExP6JV2tgXdNiNnvP8V4so75qbs O+wmETRIjfaAKxojAuuKHDp2KntWFhxyKrOq42ClAJ8Em+JvHhRYW6Vsi1g8w7pOOlz34ZYrPu8H vKTlXcxNnw3h3Kq74W4a7I/htkxNeXJdFzULHdfBR9qWJODQcqhaX2YtENwvKhOuJv4KHBnM0D4L nMgJLvlblnpHnOl68wVQdJVznjAJ85eCXuaPOQgeWeU1FEIT/wCc976qUM/iUUjXuG+v+E5+M5iS FGI6dWPPe/regjupuznixL0sAA7IF6wT700ljtizkC+p2il9Ha90OrInwMEePnWjFqmveiJdnxMa z6eg6+OGCtP95paV1yPIN93EfKo2rJgaErHgTuixO/XWb/Ew1wIDAQABo0IwQDAPBgNVHRMBAf8E BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUS8W0QGutHLOlHGVuRjaJhwUMDrYwDQYJ KoZIhvcNAQELBQADggIBAHNXPyzVlTJ+N9uWkusZXn5T50HsEbZH77Xe7XRcxfGOSeD8bpkTzZ+K 2s06Ctg6Wgk/XzTQLwPSZh0avZyQN8gMjgdalEVGKua+etqhqaRpEpKwfTbURIfXUfEpY9Z1zRbk J4kd+MIySP3bmdCPX1R0zKxnNBFi2QwKN4fRoxdIjtIXHfbX/dtl6/2o1PXWT6RbdejF0mCy2wl+ JYt7ulKSnj7oxXehPOBKc2thz4bcQ///If4jXSRK9dNtD2IEBVeC2m6kMyV5Sy5UGYvMLD0w6dEG /+gyRr61M3Z3qAFdlsHB1b6uJcDJHgoJIIihDsnzb02CVAAgp9KP5DlUFy6NHrgbuxu9mk47EDTc nIhT76IxW1hPkWLIwpqazRVdOKnWvvgTtZ8SafJQYqz7Fzf07rh1Z2AQ+4NQ+US1dZxAF7L+/Xld blhYXzD8AK6vM8EOTmy6p6ahfzLbOOCxchcKK5HsamMm7YnUeMx0HgX4a/6ManY5Ka5lIxKVCCIc l85bBu4M4ru8H0ST9tg4RQUh7eStqxK2A6RCLi3ECToDZ2mEmuFZkIoohdVddLHRDiBYmxOlsGOm 7XtH/UVVMKTumtTm4ofvmMkyghEpIrwACjFeLQ/Ajulrso8uBtjRkcfGEvRM/TAXw8HaOFvjqerm obp573PYtlNXLfbQ4ddI -----END CERTIFICATE----- Buypass Class 2 Root CA ======================= -----BEGIN CERTIFICATE----- MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU QnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3MgQ2xhc3MgMiBSb290IENBMB4X DTEwMTAyNjA4MzgwM1oXDTQwMTAyNjA4MzgwM1owTjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1 eXBhc3MgQVMtOTgzMTYzMzI3MSAwHgYDVQQDDBdCdXlwYXNzIENsYXNzIDIgUm9vdCBDQTCCAiIw DQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANfHXvfBB9R3+0Mh9PT1aeTuMgHbo4Yf5FkNuud1 g1Lr6hxhFUi7HQfKjK6w3Jad6sNgkoaCKHOcVgb/S2TwDCo3SbXlzwx87vFKu3MwZfPVL4O2fuPn 9Z6rYPnT8Z2SdIrkHJasW4DptfQxh6NR/Md+oW+OU3fUl8FVM5I+GC911K2GScuVr1QGbNgGE41b /+EmGVnAJLqBcXmQRFBoJJRfuLMR8SlBYaNByyM21cHxMlAQTn/0hpPshNOOvEu/XAFOBz3cFIqU CqTqc/sLUegTBxj6DvEr0VQVfTzh97QZQmdiXnfgolXsttlpF9U6r0TtSsWe5HonfOV116rLJeff awrbD02TTqigzXsu8lkBarcNuAeBfos4GzjmCleZPe4h6KP1DBbdi+w0jpwqHAAVF41og9JwnxgI zRFo1clrUs3ERo/ctfPYV3Me6ZQ5BL/T3jjetFPsaRyifsSP5BtwrfKi+fv3FmRmaZ9JUaLiFRhn Bkp/1Wy1TbMz4GHrXb7pmA8y1x1LPC5aAVKRCfLf6o3YBkBjqhHk/sM3nhRSP/TizPJhk9H9Z2vX Uq6/aKtAQ6BXNVN48FP4YUIHZMbXb5tMOA1jrGKvNouicwoN9SG9dKpN6nIDSdvHXx1iY8f93ZHs M+71bbRuMGjeyNYmsHVee7QHIJihdjK4TWxPAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYD VR0OBBYEFMmAd+BikoL1RpzzuvdMw964o605MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsF AAOCAgEAU18h9bqwOlI5LJKwbADJ784g7wbylp7ppHR/ehb8t/W2+xUbP6umwHJdELFx7rxP462s A20ucS6vxOOto70MEae0/0qyexAQH6dXQbLArvQsWdZHEIjzIVEpMMpghq9Gqx3tOluwlN5E40EI osHsHdb9T7bWR9AUC8rmyrV7d35BH16Dx7aMOZawP5aBQW9gkOLo+fsicdl9sz1Gv7SEr5AcD48S aq/v7h56rgJKihcrdv6sVIkkLE8/trKnToyokZf7KcZ7XC25y2a2t6hbElGFtQl+Ynhw/qlqYLYd DnkM/crqJIByw5c/8nerQyIKx+u2DISCLIBrQYoIwOula9+ZEsuK1V6ADJHgJgg2SMX6OBE1/yWD LfJ6v9r9jv6ly0UsH8SIU653DtmadsWOLB2jutXsMq7Aqqz30XpN69QH4kj3Io6wpJ9qzo6ysmD0 oyLQI+uUWnpp3Q+/QFesa1lQ2aOZ4W7+jQF5JyMV3pKdewlNWudLSDBaGOYKbeaP4NK75t98biGC wWg5TbSYWGZizEqQXsP6JwSxeRV0mcy+rSDeJmAc61ZRpqPq5KM/p/9h3PFaTWwyI0PurKju7koS CTxdccK+efrCh2gdC/1cacwG0Jp9VJkqyTkaGa9LKkPzY11aWOIv4x3kqdbQCtCev9eBCfHJxyYN rJgWVqA= -----END CERTIFICATE----- Buypass Class 3 Root CA ======================= -----BEGIN CERTIFICATE----- MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU QnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3MgQ2xhc3MgMyBSb290IENBMB4X DTEwMTAyNjA4Mjg1OFoXDTQwMTAyNjA4Mjg1OFowTjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1 eXBhc3MgQVMtOTgzMTYzMzI3MSAwHgYDVQQDDBdCdXlwYXNzIENsYXNzIDMgUm9vdCBDQTCCAiIw DQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAKXaCpUWUOOV8l6ddjEGMnqb8RB2uACatVI2zSRH sJ8YZLya9vrVediQYkwiL944PdbgqOkcLNt4EemOaFEVcsfzM4fkoF0LXOBXByow9c3EN3coTRiR 5r/VUv1xLXA+58bEiuPwKAv0dpihi4dVsjoT/Lc+JzeOIuOoTyrvYLs9tznDDgFHmV0ST9tD+leh 7fmdvhFHJlsTmKtdFoqwNxxXnUX/iJY2v7vKB3tvh2PX0DJq1l1sDPGzbjniazEuOQAnFN44wOwZ ZoYS6J1yFhNkUsepNxz9gjDthBgd9K5c/3ATAOux9TN6S9ZV+AWNS2mw9bMoNlwUxFFzTWsL8TQH 2xc519woe2v1n/MuwU8XKhDzzMro6/1rqy6any2CbgTUUgGTLT2G/H783+9CHaZr77kgxve9oKeV /afmiSTYzIw0bOIjL9kSGiG5VZFvC5F5GQytQIgLcOJ60g7YaEi7ghM5EFjp2CoHxhLbWNvSO1UQ RwUVZ2J+GGOmRj8JDlQyXr8NYnon74Do29lLBlo3WiXQCBJ31G8JUJc9yB3D34xFMFbG02SrZvPA Xpacw8Tvw3xrizp5f7NJzz3iiZ+gMEuFuZyUJHmPfWupRWgPK9Dx2hzLabjKSWJtyNBjYt1gD1iq j6G8BaVmos8bdrKEZLFMOVLAMLrwjEsCsLa3AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYD VR0OBBYEFEe4zf/lb+74suwvTg75JbCOPGvDMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsF AAOCAgEAACAjQTUEkMJAYmDv4jVM1z+s4jSQuKFvdvoWFqRINyzpkMLyPPgKn9iB5btb2iUspKdV cSQy9sgL8rxq+JOssgfCX5/bzMiKqr5qb+FJEMwx14C7u8jYog5kV+qi9cKpMRXSIGrs/CIBKM+G uIAeqcwRpTzyFrNHnfzSgCHEy9BHcEGhyoMZCCxt8l13nIoUE9Q2HJLw5QY33KbmkJs4j1xrG0aG Q0JfPgEHU1RdZX33inOhmlRaHylDFCfChQ+1iHsaO5S3HWCntZznKWlXWpuTekMwGwPXYshApqr8 ZORK15FTAaggiG6cX0S5y2CBNOxv033aSF/rtJC8LakcC6wc1aJoIIAE1vyxjy+7SjENSoYc6+I2 KSb12tjE8nVhz36udmNKekBlk4f4HoCMhuWG1o8O/FMsYOgWYRqiPkN7zTlgVGr18okmAWiDSKIz 6MkEkbIRNBE+6tBDGR8Dk5AM/1E9V/RBbuHLoL7ryWPNbczk+DaqaJ3tvV2XcEQNtg413OEMXbug UZTLfhbrES+jkkXITHHZvMmZUldGL1DPvTVp9D0VzgalLA8+9oG6lLvDu79leNKGef9JOxqDDPDe eOzI8k1MGt6CKfjBWtrt7uYnXuhF0J0cUahoq0Tj0Itq4/g7u9xN12TyUb7mqqta6THuBrxzvxNi Cp/HuZc= -----END CERTIFICATE----- T-TeleSec GlobalRoot Class 3 ============================ -----BEGIN CERTIFICATE----- MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoM IlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBU cnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwHhcNMDgx MDAxMTAyOTU2WhcNMzMxMDAxMjM1OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lz dGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBD ZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwggEiMA0GCSqGSIb3 DQEBAQUAA4IBDwAwggEKAoIBAQC9dZPwYiJvJK7genasfb3ZJNW4t/zN8ELg63iIVl6bmlQdTQyK 9tPPcPRStdiTBONGhnFBSivwKixVA9ZIw+A5OO3yXDw/RLyTPWGrTs0NvvAgJ1gORH8EGoel15YU NpDQSXuhdfsaa3Ox+M6pCSzyU9XDFES4hqX2iys52qMzVNn6chr3IhUciJFrf2blw2qAsCTz34ZF iP0Zf3WHHx+xGwpzJFu5ZeAsVMhg02YXP+HMVDNzkQI6pn97djmiH5a2OK61yJN0HZ65tOVgnS9W 0eDrXltMEnAMbEQgqxHY9Bn20pxSN+f6tsIxO0rUFJmtxxr1XV/6B7h8DR/Wgx6zAgMBAAGjQjBA MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS1A/d2O2GCahKqGFPr AyGUv/7OyjANBgkqhkiG9w0BAQsFAAOCAQEAVj3vlNW92nOyWL6ukK2YJ5f+AbGwUgC4TeQbIXQb fsDuXmkqJa9c1h3a0nnJ85cp4IaH3gRZD/FZ1GSFS5mvJQQeyUapl96Cshtwn5z2r3Ex3XsFpSzT ucpH9sry9uetuUg/vBa3wW306gmv7PO15wWeph6KU1HWk4HMdJP2udqmJQV0eVp+QD6CSyYRMG7h P0HHRwA11fXT91Q+gT3aSWqas+8QPebrb9HIIkfLzM8BMZLZGOMivgkeGj5asuRrDFR6fUNOuIml e9eiPZaGzPImNC1qkp2aGtAw4l1OBLBfiyB+d8E9lYLRRpo7PHi4b6HQDWSieB4pTpPDpFQUWw== -----END CERTIFICATE----- EE Certification Centre Root CA =============================== -----BEGIN CERTIFICATE----- MIIEAzCCAuugAwIBAgIQVID5oHPtPwBMyonY43HmSjANBgkqhkiG9w0BAQUFADB1MQswCQYDVQQG EwJFRTEiMCAGA1UECgwZQVMgU2VydGlmaXRzZWVyaW1pc2tlc2t1czEoMCYGA1UEAwwfRUUgQ2Vy dGlmaWNhdGlvbiBDZW50cmUgUm9vdCBDQTEYMBYGCSqGSIb3DQEJARYJcGtpQHNrLmVlMCIYDzIw MTAxMDMwMTAxMDMwWhgPMjAzMDEyMTcyMzU5NTlaMHUxCzAJBgNVBAYTAkVFMSIwIAYDVQQKDBlB UyBTZXJ0aWZpdHNlZXJpbWlza2Vza3VzMSgwJgYDVQQDDB9FRSBDZXJ0aWZpY2F0aW9uIENlbnRy ZSBSb290IENBMRgwFgYJKoZIhvcNAQkBFglwa2lAc2suZWUwggEiMA0GCSqGSIb3DQEBAQUAA4IB DwAwggEKAoIBAQDIIMDs4MVLqwd4lfNE7vsLDP90jmG7sWLqI9iroWUyeuuOF0+W2Ap7kaJjbMeM TC55v6kF/GlclY1i+blw7cNRfdCT5mzrMEvhvH2/UpvObntl8jixwKIy72KyaOBhU8E2lf/slLo2 rpwcpzIP5Xy0xm90/XsY6KxX7QYgSzIwWFv9zajmofxwvI6Sc9uXp3whrj3B9UiHbCe9nyV0gVWw 93X2PaRka9ZP585ArQ/dMtO8ihJTmMmJ+xAdTX7Nfh9WDSFwhfYggx/2uh8Ej+p3iDXE/+pOoYtN P2MbRMNE1CV2yreN1x5KZmTNXMWcg+HCCIia7E6j8T4cLNlsHaFLAgMBAAGjgYowgYcwDwYDVR0T AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBLyWj7qVhy/zQas8fElyalL1BSZ MEUGA1UdJQQ+MDwGCCsGAQUFBwMCBggrBgEFBQcDAQYIKwYBBQUHAwMGCCsGAQUFBwMEBggrBgEF BQcDCAYIKwYBBQUHAwkwDQYJKoZIhvcNAQEFBQADggEBAHv25MANqhlHt01Xo/6tu7Fq1Q+e2+Rj xY6hUFaTlrg4wCQiZrxTFGGVv9DHKpY5P30osxBAIWrEr7BSdxjhlthWXePdNl4dp1BUoMUq5KqM lIpPnTX/dqQGE5Gion0ARD9V04I8GtVbvFZMIi5GQ4okQC3zErg7cBqklrkar4dBGmoYDQZPxz5u uSlNDUmJEYcyW+ZLBMjkXOZ0c5RdFpgTlf7727FE5TpwrDdr5rMzcijJs1eg9gIWiAYLtqZLICjU 3j2LrTcFU3T+bsy8QxdxXvnFzBqpYe73dgzzcvRyrc9yAjYHR8/vGVCJYMzpJJUPwssd8m92kMfM dcGWxZ0= -----END CERTIFICATE----- 349ba2d6964db9ca558c9e1daf38e428 createRequest($method, $url, null, null, $options); if (isset($options['stream'])) { if ($options['stream'] instanceof StreamRequestFactoryInterface) { return $options['stream']->fromRequest($request); } elseif ($options['stream'] == true) { $streamFactory = new PhpStreamRequestFactory(); return $streamFactory->fromRequest($request); } } return $request->send(); } /** * Send a GET request * * @param string $url URL of the request * @param array $options Array of request options * * @return \Guzzle\Http\Message\Response * @see Guzzle::request for a list of available options */ public static function get($url, $options = array()) { return self::request('GET', $url, $options); } /** * Send a HEAD request * * @param string $url URL of the request * @param array $options Array of request options * * @return \Guzzle\Http\Message\Response * @see Guzzle::request for a list of available options */ public static function head($url, $options = array()) { return self::request('HEAD', $url, $options); } /** * Send a DELETE request * * @param string $url URL of the request * @param array $options Array of request options * * @return \Guzzle\Http\Message\Response * @see Guzzle::request for a list of available options */ public static function delete($url, $options = array()) { return self::request('DELETE', $url, $options); } /** * Send a POST request * * @param string $url URL of the request * @param array $options Array of request options * * @return \Guzzle\Http\Message\Response * @see Guzzle::request for a list of available options */ public static function post($url, $options = array()) { return self::request('POST', $url, $options); } /** * Send a PUT request * * @param string $url URL of the request * @param array $options Array of request options * * @return \Guzzle\Http\Message\Response * @see Guzzle::request for a list of available options */ public static function put($url, $options = array()) { return self::request('PUT', $url, $options); } /** * Send a PATCH request * * @param string $url URL of the request * @param array $options Array of request options * * @return \Guzzle\Http\Message\Response * @see Guzzle::request for a list of available options */ public static function patch($url, $options = array()) { return self::request('PATCH', $url, $options); } /** * Send an OPTIONS request * * @param string $url URL of the request * @param array $options Array of request options * * @return \Guzzle\Http\Message\Response * @see Guzzle::request for a list of available options */ public static function options($url, $options = array()) { return self::request('OPTIONS', $url, $options); } } null, 'host' => null, 'path' => null, 'port' => null, 'query' => null, 'user' => null, 'pass' => null, 'fragment' => null); if (false === ($parts = parse_url($url))) { throw new InvalidArgumentException('Was unable to parse malformed url: ' . $url); } $parts += $defaults; // Convert the query string into a QueryString object if ($parts['query'] || 0 !== strlen($parts['query'])) { $parts['query'] = QueryString::fromString($parts['query']); } return new static($parts['scheme'], $parts['host'], $parts['user'], $parts['pass'], $parts['port'], $parts['path'], $parts['query'], $parts['fragment']); } /** * Build a URL from parse_url parts. The generated URL will be a relative URL if a scheme or host are not provided. * * @param array $parts Array of parse_url parts * * @return string */ public static function buildUrl(array $parts) { $url = $scheme = ''; if (isset($parts['scheme'])) { $scheme = $parts['scheme']; $url .= $scheme . ':'; } if (isset($parts['host'])) { $url .= '//'; if (isset($parts['user'])) { $url .= $parts['user']; if (isset($parts['pass'])) { $url .= ':' . $parts['pass']; } $url .= '@'; } $url .= $parts['host']; // Only include the port if it is not the default port of the scheme if (isset($parts['port']) && !(($scheme == 'http' && $parts['port'] == 80) || ($scheme == 'https' && $parts['port'] == 443)) ) { $url .= ':' . $parts['port']; } } // Add the path component if present if (isset($parts['path']) && 0 !== strlen($parts['path'])) { // Always ensure that the path begins with '/' if set and something is before the path if ($url && $parts['path'][0] != '/' && substr($url, -1) != '/') { $url .= '/'; } $url .= $parts['path']; } // Add the query string if present if (isset($parts['query'])) { $url .= '?' . $parts['query']; } // Ensure that # is only added to the url if fragment contains anything. if (isset($parts['fragment'])) { $url .= '#' . $parts['fragment']; } return $url; } /** * Create a new URL from URL parts * * @param string $scheme Scheme of the URL * @param string $host Host of the URL * @param string $username Username of the URL * @param string $password Password of the URL * @param int $port Port of the URL * @param string $path Path of the URL * @param QueryString|array|string $query Query string of the URL * @param string $fragment Fragment of the URL */ public function __construct($scheme, $host, $username = null, $password = null, $port = null, $path = null, QueryString $query = null, $fragment = null) { $this->scheme = $scheme; $this->host = $host; $this->port = $port; $this->username = $username; $this->password = $password; $this->fragment = $fragment; if (!$query) { $this->query = new QueryString(); } else { $this->setQuery($query); } $this->setPath($path); } /** * Clone the URL */ public function __clone() { $this->query = clone $this->query; } /** * Returns the URL as a URL string * * @return string */ public function __toString() { return self::buildUrl($this->getParts()); } /** * Get the parts of the URL as an array * * @return array */ public function getParts() { $query = (string) $this->query; return array( 'scheme' => $this->scheme, 'user' => $this->username, 'pass' => $this->password, 'host' => $this->host, 'port' => $this->port, 'path' => $this->getPath(), 'query' => $query !== '' ? $query : null, 'fragment' => $this->fragment, ); } /** * Set the host of the request. * * @param string $host Host to set (e.g. www.yahoo.com, yahoo.com) * * @return Url */ public function setHost($host) { if (strpos($host, ':') === false) { $this->host = $host; } else { list($host, $port) = explode(':', $host); $this->host = $host; $this->setPort($port); } return $this; } /** * Get the host part of the URL * * @return string */ public function getHost() { return $this->host; } /** * Set the scheme part of the URL (http, https, ftp, etc) * * @param string $scheme Scheme to set * * @return Url */ public function setScheme($scheme) { $this->scheme = $scheme; return $this; } /** * Get the scheme part of the URL * * @return string */ public function getScheme() { return $this->scheme; } /** * Set the port part of the URL * * @param int $port Port to set * * @return Url */ public function setPort($port) { $this->port = $port; return $this; } /** * Get the port part of the URl. Will return the default port for a given scheme if no port has been set. * * @return int|null */ public function getPort() { if ($this->port) { return $this->port; } elseif ($this->scheme == 'http') { return 80; } elseif ($this->scheme == 'https') { return 443; } return null; } /** * Set the path part of the URL * * @param array|string $path Path string or array of path segments * * @return Url */ public function setPath($path) { static $pathReplace = array(' ' => '%20', '?' => '%3F'); if (is_array($path)) { $path = '/' . implode('/', $path); } $this->path = strtr($path, $pathReplace); return $this; } /** * Normalize the URL so that double slashes and relative paths are removed * * @return Url */ public function normalizePath() { if (!$this->path || $this->path == '/' || $this->path == '*') { return $this; } $results = array(); $segments = $this->getPathSegments(); foreach ($segments as $segment) { if ($segment == '..') { array_pop($results); } elseif ($segment != '.' && $segment != '') { $results[] = $segment; } } // Combine the normalized parts and add the leading slash if needed $this->path = ($this->path[0] == '/' ? '/' : '') . implode('/', $results); // Add the trailing slash if necessary if ($this->path != '/' && end($segments) == '') { $this->path .= '/'; } return $this; } /** * Add a relative path to the currently set path * * @param string $relativePath Relative path to add * * @return Url */ public function addPath($relativePath) { if (!$relativePath || $relativePath == '/') { return $this; } // Add a leading slash if needed if ($relativePath[0] != '/') { $relativePath = '/' . $relativePath; } return $this->setPath(str_replace('//', '/', $this->getPath() . $relativePath)); } /** * Get the path part of the URL * * @return string */ public function getPath() { return $this->path; } /** * Get the path segments of the URL as an array * * @return array */ public function getPathSegments() { return array_slice(explode('/', $this->getPath()), 1); } /** * Set the password part of the URL * * @param string $password Password to set * * @return Url */ public function setPassword($password) { $this->password = $password; return $this; } /** * Get the password part of the URL * * @return null|string */ public function getPassword() { return $this->password; } /** * Set the username part of the URL * * @param string $username Username to set * * @return Url */ public function setUsername($username) { $this->username = $username; return $this; } /** * Get the username part of the URl * * @return null|string */ public function getUsername() { return $this->username; } /** * Get the query part of the URL as a QueryString object * * @return QueryString */ public function getQuery() { return $this->query; } /** * Set the query part of the URL * * @param QueryString|string|array $query Query to set * * @return Url */ public function setQuery($query) { if (is_string($query)) { $output = null; parse_str($query, $output); $this->query = new QueryString($output); } elseif (is_array($query)) { $this->query = new QueryString($query); } elseif ($query instanceof QueryString) { $this->query = $query; } return $this; } /** * Get the fragment part of the URL * * @return null|string */ public function getFragment() { return $this->fragment; } /** * Set the fragment part of the URL * * @param string $fragment Fragment to set * * @return Url */ public function setFragment($fragment) { $this->fragment = $fragment; return $this; } /** * Check if this is an absolute URL * * @return bool */ public function isAbsolute() { return $this->scheme && $this->host; } /** * Combine the URL with another URL. Follows the rules specific in RFC 3986 section 5.4. * * @param string $url Relative URL to combine with * @param bool $strictRfc3986 Set to true to use strict RFC 3986 compliance when merging paths. When first * released, Guzzle used an incorrect algorithm for combining relative URL paths. In * order to not break users, we introduced this flag to allow the merging of URLs based * on strict RFC 3986 section 5.4.1. This means that "http://a.com/foo/baz" merged with * "bar" would become "http://a.com/foo/bar". When this value is set to false, it would * become "http://a.com/foo/baz/bar". * @return Url * @throws InvalidArgumentException * @link http://tools.ietf.org/html/rfc3986#section-5.4 */ public function combine($url, $strictRfc3986 = false) { $url = self::factory($url); // Use the more absolute URL as the base URL if (!$this->isAbsolute() && $url->isAbsolute()) { $url = $url->combine($this); } // Passing a URL with a scheme overrides everything if ($buffer = $url->getScheme()) { $this->scheme = $buffer; $this->host = $url->getHost(); $this->port = $url->getPort(); $this->username = $url->getUsername(); $this->password = $url->getPassword(); $this->path = $url->getPath(); $this->query = $url->getQuery(); $this->fragment = $url->getFragment(); return $this; } // Setting a host overrides the entire rest of the URL if ($buffer = $url->getHost()) { $this->host = $buffer; $this->port = $url->getPort(); $this->username = $url->getUsername(); $this->password = $url->getPassword(); $this->path = $url->getPath(); $this->query = $url->getQuery(); $this->fragment = $url->getFragment(); return $this; } $path = $url->getPath(); $query = $url->getQuery(); if (!$path) { if (count($query)) { $this->addQuery($query, $strictRfc3986); } } else { if ($path[0] == '/') { $this->path = $path; } elseif ($strictRfc3986) { $this->path .= '/../' . $path; } else { $this->path .= '/' . $path; } $this->normalizePath(); $this->addQuery($query, $strictRfc3986); } $this->fragment = $url->getFragment(); return $this; } private function addQuery(QueryString $new, $strictRfc386) { if (!$strictRfc386) { $new->merge($this->query); } $this->query = $new; } } array(), 'camel' => array() ); /** @var int Max entries per cache */ protected $maxCacheSize; /** @var InflectorInterface Decorated inflector */ protected $decoratedInflector; /** * @param InflectorInterface $inflector Inflector being decorated * @param int $maxCacheSize Maximum number of cached items to hold per cache */ public function __construct(InflectorInterface $inflector, $maxCacheSize = 500) { $this->decoratedInflector = $inflector; $this->maxCacheSize = $maxCacheSize; } public function snake($word) { if (!isset($this->cache['snake'][$word])) { $this->pruneCache('snake'); $this->cache['snake'][$word] = $this->decoratedInflector->snake($word); } return $this->cache['snake'][$word]; } /** * Converts strings from snake_case to upper CamelCase * * @param string $word Value to convert into upper CamelCase * * @return string */ public function camel($word) { if (!isset($this->cache['camel'][$word])) { $this->pruneCache('camel'); $this->cache['camel'][$word] = $this->decoratedInflector->camel($word); } return $this->cache['camel'][$word]; } /** * Prune one of the named caches by removing 20% of the cache if it is full * * @param string $cache Type of cache to prune */ protected function pruneCache($cache) { if (count($this->cache[$cache]) == $this->maxCacheSize) { $this->cache[$cache] = array_slice($this->cache[$cache], $this->maxCacheSize * 0.2); } } } array(), 'camel' => array() ); /** @var InflectorInterface Decorated inflector */ protected $decoratedInflector; /** * @param InflectorInterface $inflector Inflector being decorated * @param array $snake Hash of pre-computed camel to snake * @param array $camel Hash of pre-computed snake to camel * @param bool $mirror Mirror snake and camel reflections */ public function __construct(InflectorInterface $inflector, array $snake = array(), array $camel = array(), $mirror = false) { if ($mirror) { $camel = array_merge(array_flip($snake), $camel); $snake = array_merge(array_flip($camel), $snake); } $this->decoratedInflector = $inflector; $this->mapping = array( 'snake' => $snake, 'camel' => $camel ); } public function snake($word) { return isset($this->mapping['snake'][$word]) ? $this->mapping['snake'][$word] : $this->decoratedInflector->snake($word); } /** * Converts strings from snake_case to upper CamelCase * * @param string $word Value to convert into upper CamelCase * * @return string */ public function camel($word) { return isset($this->mapping['camel'][$word]) ? $this->mapping['camel'][$word] : $this->decoratedInflector->camel($word); } } getArrayIterator()->append($iterator); } } chunkSize = $chunkSize; } public function rewind() { parent::rewind(); $this->next(); } public function next() { $this->chunk = array(); for ($i = 0; $i < $this->chunkSize && parent::valid(); $i++) { $this->chunk[] = parent::current(); parent::next(); } } public function current() { return $this->chunk; } public function valid() { return (bool) $this->chunk; } } callback = $callback; } public function accept() { return call_user_func($this->callback, $this->current()); } } callback = $callback; } public function current() { return call_user_func($this->callback, parent::current()); } } getInnerIterator(); while ($i instanceof \OuterIterator) { $i = $i->getInnerIterator(); } return call_user_func_array(array($i, $name), $args); } } log; } } logs[] = array('message' => $message, 'priority' => $priority, 'extras' => $extras); } /** * Get logged entries * * @return array */ public function getLogs() { return $this->logs; } /** * Clears logged entries */ public function clearLogs() { $this->logs = array(); } } log = $logObject; } public function log($message, $priority = LOG_INFO, $extras = array()) { call_user_func($this->log, $message, $priority, $extras); } } >>>>>>>\n{request}\n<<<<<<<<\n{response}\n--------\n{curl_stderr}"; const SHORT_FORMAT = '[{ts}] "{method} {resource} {protocol}/{version}" {code}'; /** * @var string Template used to format log messages */ protected $template; /** * @param string $template Log message template */ public function __construct($template = self::DEFAULT_FORMAT) { $this->template = $template ?: self::DEFAULT_FORMAT; } /** * Set the template to use for logging * * @param string $template Log message template * * @return self */ public function setTemplate($template) { $this->template = $template; return $this; } /** * Returns a formatted message * * @param RequestInterface $request Request that was sent * @param Response $response Response that was received * @param CurlHandle $handle Curl handle associated with the message * @param array $customData Associative array of custom template data * * @return string */ public function format( RequestInterface $request, Response $response = null, CurlHandle $handle = null, array $customData = array() ) { $cache = $customData; return preg_replace_callback( '/{\s*([A-Za-z_\-\.0-9]+)\s*}/', function (array $matches) use ($request, $response, $handle, &$cache) { if (array_key_exists($matches[1], $cache)) { return $cache[$matches[1]]; } $result = ''; switch ($matches[1]) { case 'request': $result = (string) $request; break; case 'response': $result = (string) $response; break; case 'req_body': $result = $request instanceof EntityEnclosingRequestInterface ? (string) $request->getBody() : ''; break; case 'res_body': $result = $response ? $response->getBody(true) : ''; break; case 'ts': $result = gmdate('c'); break; case 'method': $result = $request->getMethod(); break; case 'url': $result = (string) $request->getUrl(); break; case 'resource': $result = $request->getResource(); break; case 'protocol': $result = 'HTTP'; break; case 'version': $result = $request->getProtocolVersion(); break; case 'host': $result = $request->getHost(); break; case 'hostname': $result = gethostname(); break; case 'port': $result = $request->getPort(); break; case 'code': $result = $response ? $response->getStatusCode() : ''; break; case 'phrase': $result = $response ? $response->getReasonPhrase() : ''; break; case 'connect_time': $result = $handle && $handle->getInfo(CURLINFO_CONNECT_TIME) ? $handle->getInfo(CURLINFO_CONNECT_TIME) : ($response ? $response->getInfo('connect_time') : ''); break; case 'total_time': $result = $handle && $handle->getInfo(CURLINFO_TOTAL_TIME) ? $handle->getInfo(CURLINFO_TOTAL_TIME) : ($response ? $response->getInfo('total_time') : ''); break; case 'curl_error': $result = $handle ? $handle->getError() : ''; break; case 'curl_code': $result = $handle ? $handle->getErrorNo() : ''; break; case 'curl_stderr': $result = $handle ? $handle->getStderr() : ''; break; default: if (strpos($matches[1], 'req_header_') === 0) { $result = $request->getHeader(substr($matches[1], 11)); } elseif ($response && strpos($matches[1], 'res_header_') === 0) { $result = $response->getHeader(substr($matches[1], 11)); } } $cache[$matches[1]] = $result; return $result; }, $this->template ); } } Logger::DEBUG, LOG_INFO => Logger::INFO, LOG_WARNING => Logger::WARNING, LOG_ERR => Logger::ERROR, LOG_CRIT => Logger::CRITICAL, LOG_ALERT => Logger::ALERT ); public function __construct(Logger $logObject) { $this->log = $logObject; } public function log($message, $priority = LOG_INFO, $extras = array()) { $this->log->addRecord(self::$mapping[$priority], $message); } } LogLevel::DEBUG, LOG_INFO => LogLevel::INFO, LOG_WARNING => LogLevel::WARNING, LOG_ERR => LogLevel::ERROR, LOG_CRIT => LogLevel::CRITICAL, LOG_ALERT => LogLevel::ALERT ); public function __construct(LoggerInterface $logObject) { $this->log = $logObject; } public function log($message, $priority = LOG_INFO, $extras = array()) { $this->log->log(self::$mapping[$priority], $message, $extras); } } log = $logObject; Version::warn(__CLASS__ . ' is deprecated'); } public function log($message, $priority = LOG_INFO, $extras = array()) { $this->log->log($message, $priority, $extras); } } log = $logObject; } public function log($message, $priority = LOG_INFO, $extras = array()) { $this->log->log($priority, $message, $extras); } } 'Domain', 'path' => 'Path', 'max_age' => 'Max-Age', 'expires' => 'Expires', 'version' => 'Version', 'secure' => 'Secure', 'port' => 'Port', 'discard' => 'Discard', 'comment' => 'Comment', 'comment_url' => 'Comment-Url', 'http_only' => 'HttpOnly' ); public function parseCookie($cookie, $host = null, $path = null, $decode = false) { // Explode the cookie string using a series of semicolons $pieces = array_filter(array_map('trim', explode(';', $cookie))); // The name of the cookie (first kvp) must include an equal sign. if (empty($pieces) || !strpos($pieces[0], '=')) { return false; } // Create the default return array $data = array_merge(array_fill_keys(array_keys(self::$cookieParts), null), array( 'cookies' => array(), 'data' => array(), 'path' => $path ?: '/', 'http_only' => false, 'discard' => false, 'domain' => $host )); $foundNonCookies = 0; // Add the cookie pieces into the parsed data array foreach ($pieces as $part) { $cookieParts = explode('=', $part, 2); $key = trim($cookieParts[0]); if (count($cookieParts) == 1) { // Can be a single value (e.g. secure, httpOnly) $value = true; } else { // Be sure to strip wrapping quotes $value = trim($cookieParts[1], " \n\r\t\0\x0B\""); if ($decode) { $value = urldecode($value); } } // Only check for non-cookies when cookies have been found if (!empty($data['cookies'])) { foreach (self::$cookieParts as $mapValue => $search) { if (!strcasecmp($search, $key)) { $data[$mapValue] = $mapValue == 'port' ? array_map('trim', explode(',', $value)) : $value; $foundNonCookies++; continue 2; } } } // If cookies have not yet been retrieved, or this value was not found in the pieces array, treat it as a // cookie. IF non-cookies have been parsed, then this isn't a cookie, it's cookie data. Cookies then data. $data[$foundNonCookies ? 'data' : 'cookies'][$key] = $value; } // Calculate the expires date if (!$data['expires'] && $data['max_age']) { $data['expires'] = time() + (int) $data['max_age']; } return $data; } } $requestUrl, 'scheme' => 'http' ); // Check for the Host header if (isset($parts['headers']['Host'])) { $urlParts['host'] = $parts['headers']['Host']; } elseif (isset($parts['headers']['host'])) { $urlParts['host'] = $parts['headers']['host']; } else { $urlParts['host'] = null; } if (false === strpos($urlParts['host'], ':')) { $urlParts['port'] = ''; } else { $hostParts = explode(':', $urlParts['host']); $urlParts['host'] = trim($hostParts[0]); $urlParts['port'] = (int) trim($hostParts[1]); if ($urlParts['port'] == 443) { $urlParts['scheme'] = 'https'; } } // Check if a query is present $path = $urlParts['path']; $qpos = strpos($path, '?'); if ($qpos) { $urlParts['query'] = substr($path, $qpos + 1); $urlParts['path'] = substr($path, 0, $qpos); } else { $urlParts['query'] = ''; } return $urlParts; } } parseMessage($message); // Parse the protocol and protocol version if (isset($parts['start_line'][2])) { $startParts = explode('/', $parts['start_line'][2]); $protocol = strtoupper($startParts[0]); $version = isset($startParts[1]) ? $startParts[1] : '1.1'; } else { $protocol = 'HTTP'; $version = '1.1'; } $parsed = array( 'method' => strtoupper($parts['start_line'][0]), 'protocol' => $protocol, 'version' => $version, 'headers' => $parts['headers'], 'body' => $parts['body'] ); $parsed['request_url'] = $this->getUrlPartsFromMessage($parts['start_line'][1], $parsed); return $parsed; } public function parseResponse($message) { if (!$message) { return false; } $parts = $this->parseMessage($message); list($protocol, $version) = explode('/', trim($parts['start_line'][0])); return array( 'protocol' => $protocol, 'version' => $version, 'code' => $parts['start_line'][1], 'reason_phrase' => isset($parts['start_line'][2]) ? $parts['start_line'][2] : '', 'headers' => $parts['headers'], 'body' => $parts['body'] ); } /** * Parse a message into parts * * @param string $message Message to parse * * @return array */ protected function parseMessage($message) { $startLine = null; $headers = array(); $body = ''; // Iterate over each line in the message, accounting for line endings $lines = preg_split('/(\\r?\\n)/', $message, -1, PREG_SPLIT_DELIM_CAPTURE); for ($i = 0, $totalLines = count($lines); $i < $totalLines; $i += 2) { $line = $lines[$i]; // If two line breaks were encountered, then this is the end of body if (empty($line)) { if ($i < $totalLines - 1) { $body = implode('', array_slice($lines, $i + 2)); } break; } // Parse message headers if (!$startLine) { $startLine = explode(' ', $line, 3); } elseif (strpos($line, ':')) { $parts = explode(':', $line, 2); $key = trim($parts[0]); $value = isset($parts[1]) ? trim($parts[1]) : ''; if (!isset($headers[$key])) { $headers[$key] = $value; } elseif (!is_array($headers[$key])) { $headers[$key] = array($headers[$key], $value); } else { $headers[$key][] = $value; } } } return array( 'start_line' => $startLine, 'headers' => $headers, 'body' => $body ); } } $parts->requestMethod, 'protocol' => 'HTTP', 'version' => number_format($parts->httpVersion, 1), 'headers' => $parts->headers, 'body' => $parts->body ); $parsed['request_url'] = $this->getUrlPartsFromMessage($parts->requestUrl, $parsed); return $parsed; } public function parseResponse($message) { if (!$message) { return false; } $parts = http_parse_message($message); return array( 'protocol' => 'HTTP', 'version' => number_format($parts->httpVersion, 1), 'code' => $parts->responseCode, 'reason_phrase' => $parts->responseStatus, 'headers' => $parts->headers, 'body' => $parts->body ); } } 'Guzzle\\Parser\\Message\\MessageParser', 'cookie' => 'Guzzle\\Parser\\Cookie\\CookieParser', 'url' => 'Guzzle\\Parser\\Url\\UrlParser', 'uri_template' => 'Guzzle\\Parser\\UriTemplate\\UriTemplate', ); /** * @return self * @codeCoverageIgnore */ public static function getInstance() { if (!self::$instance) { self::$instance = new static; } return self::$instance; } public function __construct() { // Use the PECL URI template parser if available if (extension_loaded('uri_template')) { $this->mapping['uri_template'] = 'Guzzle\\Parser\\UriTemplate\\PeclUriTemplate'; } } /** * Get a parser by name from an instance * * @param string $name Name of the parser to retrieve * * @return mixed|null */ public function getParser($name) { if (!isset($this->instances[$name])) { if (!isset($this->mapping[$name])) { return null; } $class = $this->mapping[$name]; $this->instances[$name] = new $class(); } return $this->instances[$name]; } /** * Register a custom parser by name with the register * * @param string $name Name or handle of the parser to register * @param mixed $parser Instantiated parser to register */ public function registerParser($name, $parser) { $this->instances[$name] = $parser; } } true, '#' => true, '.' => true, '/' => true, ';' => true, '?' => true, '&' => true ); /** @var array Delimiters */ private static $delims = array( ':', '/', '?', '#', '[', ']', '@', '!', '$', '&', '\'', '(', ')', '*', '+', ',', ';', '=' ); /** @var array Percent encoded delimiters */ private static $delimsPct = array( '%3A', '%2F', '%3F', '%23', '%5B', '%5D', '%40', '%21', '%24', '%26', '%27', '%28', '%29', '%2A', '%2B', '%2C', '%3B', '%3D' ); public function expand($template, array $variables) { if ($this->regex == self::DEFAULT_PATTERN && false === strpos($template, '{')) { return $template; } $this->template = $template; $this->variables = $variables; return preg_replace_callback($this->regex, array($this, 'expandMatch'), $this->template); } /** * Set the regex patten used to expand URI templates * * @param string $regexPattern */ public function setRegex($regexPattern) { $this->regex = $regexPattern; } /** * Parse an expression into parts * * @param string $expression Expression to parse * * @return array Returns an associative array of parts */ private function parseExpression($expression) { // Check for URI operators $operator = ''; if (isset(self::$operatorHash[$expression[0]])) { $operator = $expression[0]; $expression = substr($expression, 1); } $values = explode(',', $expression); foreach ($values as &$value) { $value = trim($value); $varspec = array(); $substrPos = strpos($value, ':'); if ($substrPos) { $varspec['value'] = substr($value, 0, $substrPos); $varspec['modifier'] = ':'; $varspec['position'] = (int) substr($value, $substrPos + 1); } elseif (substr($value, -1) == '*') { $varspec['modifier'] = '*'; $varspec['value'] = substr($value, 0, -1); } else { $varspec['value'] = (string) $value; $varspec['modifier'] = ''; } $value = $varspec; } return array( 'operator' => $operator, 'values' => $values ); } /** * Process an expansion * * @param array $matches Matches met in the preg_replace_callback * * @return string Returns the replacement string */ private function expandMatch(array $matches) { static $rfc1738to3986 = array( '+' => '%20', '%7e' => '~' ); $parsed = self::parseExpression($matches[1]); $replacements = array(); $prefix = $parsed['operator']; $joiner = $parsed['operator']; $useQueryString = false; if ($parsed['operator'] == '?') { $joiner = '&'; $useQueryString = true; } elseif ($parsed['operator'] == '&') { $useQueryString = true; } elseif ($parsed['operator'] == '#') { $joiner = ','; } elseif ($parsed['operator'] == ';') { $useQueryString = true; } elseif ($parsed['operator'] == '' || $parsed['operator'] == '+') { $joiner = ','; $prefix = ''; } foreach ($parsed['values'] as $value) { if (!array_key_exists($value['value'], $this->variables) || $this->variables[$value['value']] === null) { continue; } $variable = $this->variables[$value['value']]; $actuallyUseQueryString = $useQueryString; $expanded = ''; if (is_array($variable)) { $isAssoc = $this->isAssoc($variable); $kvp = array(); foreach ($variable as $key => $var) { if ($isAssoc) { $key = rawurlencode($key); $isNestedArray = is_array($var); } else { $isNestedArray = false; } if (!$isNestedArray) { $var = rawurlencode($var); if ($parsed['operator'] == '+' || $parsed['operator'] == '#') { $var = $this->decodeReserved($var); } } if ($value['modifier'] == '*') { if ($isAssoc) { if ($isNestedArray) { // Nested arrays must allow for deeply nested structures $var = strtr(http_build_query(array($key => $var)), $rfc1738to3986); } else { $var = $key . '=' . $var; } } elseif ($key > 0 && $actuallyUseQueryString) { $var = $value['value'] . '=' . $var; } } $kvp[$key] = $var; } if (empty($variable)) { $actuallyUseQueryString = false; } elseif ($value['modifier'] == '*') { $expanded = implode($joiner, $kvp); if ($isAssoc) { // Don't prepend the value name when using the explode modifier with an associative array $actuallyUseQueryString = false; } } else { if ($isAssoc) { // When an associative array is encountered and the explode modifier is not set, then the // result must be a comma separated list of keys followed by their respective values. foreach ($kvp as $k => &$v) { $v = $k . ',' . $v; } } $expanded = implode(',', $kvp); } } else { if ($value['modifier'] == ':') { $variable = substr($variable, 0, $value['position']); } $expanded = rawurlencode($variable); if ($parsed['operator'] == '+' || $parsed['operator'] == '#') { $expanded = $this->decodeReserved($expanded); } } if ($actuallyUseQueryString) { if (!$expanded && $joiner != '&') { $expanded = $value['value']; } else { $expanded = $value['value'] . '=' . $expanded; } } $replacements[] = $expanded; } $ret = implode($joiner, $replacements); if ($ret && $prefix) { return $prefix . $ret; } return $ret; } /** * Determines if an array is associative * * @param array $array Array to check * * @return bool */ private function isAssoc(array $array) { return (bool) count(array_filter(array_keys($array), 'is_string')); } /** * Removes percent encoding on reserved characters (used with + and # modifiers) * * @param string $string String to fix * * @return string */ private function decodeReserved($string) { return str_replace(self::$delimsPct, self::$delims, $string); } } utf8 = $utf8; } public function parseUrl($url) { Version::warn(__CLASS__ . ' is deprecated. Just use parse_url()'); static $defaults = array('scheme' => null, 'host' => null, 'path' => null, 'port' => null, 'query' => null, 'user' => null, 'pass' => null, 'fragment' => null); $parts = parse_url($url); // Need to handle query parsing specially for UTF-8 requirements if ($this->utf8 && isset($parts['query'])) { $queryPos = strpos($url, '?'); if (isset($parts['fragment'])) { $parts['query'] = substr($url, $queryPos + 1, strpos($url, '#') - $queryPos - 1); } else { $parts['query'] = substr($url, $queryPos + 1); } } return $parts + $defaults; } } 'onBeforeSend', 'request.exception' => 'onRequestTimeout', 'request.sent' => 'onRequestSent', 'curl.callback.progress' => 'onCurlProgress' ); } /** * Event used to ensure that progress callback are emitted from the curl handle's request mediator. * * @param Event $event */ public function onBeforeSend(Event $event) { // Ensure that progress callbacks are dispatched $event['request']->getCurlOptions()->set('progress', true); } /** * Event emitted when a curl progress function is called. When the amount of data uploaded == the amount of data to * upload OR any bytes have been downloaded, then time the request out after 1ms because we're done with * transmitting the request, and tell curl not download a body. * * @param Event $event */ public function onCurlProgress(Event $event) { if ($event['handle'] && ($event['downloaded'] || (isset($event['uploaded']) && $event['upload_size'] === $event['uploaded'])) ) { // Timeout after 1ms curl_setopt($event['handle'], CURLOPT_TIMEOUT_MS, 1); // Even if the response is quick, tell curl not to download the body. // - Note that we can only perform this shortcut if the request transmitted a body so as to ensure that the // request method is not converted to a HEAD request before the request was sent via curl. if ($event['uploaded']) { curl_setopt($event['handle'], CURLOPT_NOBODY, true); } } } /** * Event emitted when a curl exception occurs. Ignore the exception and set a mock response. * * @param Event $event */ public function onRequestTimeout(Event $event) { if ($event['exception'] instanceof CurlException) { $event['request']->setResponse(new Response(200, array( 'X-Guzzle-Async' => 'Did not wait for the response' ))); } } /** * Event emitted when a request completes because it took less than 1ms. Add an X-Guzzle-Async header to notify the * caller that there is no body in the message. * * @param Event $event */ public function onRequestSent(Event $event) { // Let the caller know this was meant to be async $event['request']->getResponse()->setHeader('X-Guzzle-Async', 'Did not wait for the response'); } } next = $next; } /** * Get the next backoff strategy in the chain * * @return AbstractBackoffStrategy|null */ public function getNext() { return $this->next; } public function getBackoffPeriod( $retries, RequestInterface $request, Response $response = null, HttpException $e = null ) { $delay = $this->getDelay($retries, $request, $response, $e); if ($delay === false) { // The strategy knows that this must not be retried return false; } elseif ($delay === null) { // If the strategy is deferring a decision and the next strategy will not make a decision then return false return !$this->next || !$this->next->makesDecision() ? false : $this->next->getBackoffPeriod($retries, $request, $response, $e); } elseif ($delay === true) { // if the strategy knows that it must retry but is deferring to the next to determine the delay if (!$this->next) { return 0; } else { $next = $this->next; while ($next->makesDecision() && $next->getNext()) { $next = $next->getNext(); } return !$next->makesDecision() ? $next->getBackoffPeriod($retries, $request, $response, $e) : 0; } } else { return $delay; } } /** * Check if the strategy does filtering and makes decisions on whether or not to retry. * * Strategies that return false will never retry if all of the previous strategies in a chain defer on a backoff * decision. * * @return bool */ abstract public function makesDecision(); /** * Implement the concrete strategy * * @param int $retries Number of retries of the request * @param RequestInterface $request Request that was sent * @param Response $response Response that was received. Note that there may not be a response * @param HttpException $e Exception that was encountered if any * * @return bool|int|null Returns false to not retry or the number of seconds to delay between retries. Return true * or null to defer to the next strategy if available, and if not, return 0. */ abstract protected function getDelay( $retries, RequestInterface $request, Response $response = null, HttpException $e = null ); } errorCodes = array_fill_keys($codes ?: static::$defaultErrorCodes, 1); $this->next = $next; } /** * Get the default failure codes to retry * * @return array */ public static function getDefaultFailureCodes() { return static::$defaultErrorCodes; } public function makesDecision() { return true; } } logger = $logger; $this->formatter = $formatter ?: new MessageFormatter(self::DEFAULT_FORMAT); } public static function getSubscribedEvents() { return array(BackoffPlugin::RETRY_EVENT => 'onRequestRetry'); } /** * Set the template to use for logging * * @param string $template Log message template * * @return self */ public function setTemplate($template) { $this->formatter->setTemplate($template); return $this; } /** * Called when a request is being retried * * @param Event $event Event emitted */ public function onRequestRetry(Event $event) { $this->logger->log($this->formatter->format( $event['request'], $event['response'], $event['handle'], array( 'retries' => $event['retries'], 'delay' => $event['delay'] ) )); } } strategy = $strategy; } /** * Retrieve a basic truncated exponential backoff plugin that will retry HTTP errors and cURL errors * * @param int $maxRetries Maximum number of retries * @param array $httpCodes HTTP response codes to retry * @param array $curlCodes cURL error codes to retry * * @return self */ public static function getExponentialBackoff( $maxRetries = 3, array $httpCodes = null, array $curlCodes = null ) { return new self(new TruncatedBackoffStrategy($maxRetries, new HttpBackoffStrategy($httpCodes, new CurlBackoffStrategy($curlCodes, new ExponentialBackoffStrategy() ) ) )); } public static function getAllEvents() { return array(self::RETRY_EVENT); } public static function getSubscribedEvents() { return array( 'request.sent' => 'onRequestSent', 'request.exception' => 'onRequestSent', CurlMultiInterface::POLLING_REQUEST => 'onRequestPoll' ); } /** * Called when a request has been sent and isn't finished processing * * @param Event $event */ public function onRequestSent(Event $event) { $request = $event['request']; $response = $event['response']; $exception = $event['exception']; $params = $request->getParams(); $retries = (int) $params->get(self::RETRY_PARAM); $delay = $this->strategy->getBackoffPeriod($retries, $request, $response, $exception); if ($delay !== false) { // Calculate how long to wait until the request should be retried $params->set(self::RETRY_PARAM, ++$retries) ->set(self::DELAY_PARAM, microtime(true) + $delay); // Send the request again $request->setState(RequestInterface::STATE_TRANSFER); $this->dispatch(self::RETRY_EVENT, array( 'request' => $request, 'response' => $response, 'handle' => ($exception && $exception instanceof CurlException) ? $exception->getCurlHandle() : null, 'retries' => $retries, 'delay' => $delay )); } } /** * Called when a request is polling in the curl multi object * * @param Event $event */ public function onRequestPoll(Event $event) { $request = $event['request']; $delay = $request->getParams()->get(self::DELAY_PARAM); // If the duration of the delay has passed, retry the request using the pool if (null !== $delay && microtime(true) >= $delay) { // Remove the request from the pool and then add it back again. This is required for cURL to know that we // want to retry sending the easy handle. $request->getParams()->remove(self::DELAY_PARAM); // Rewind the request body if possible if ($request instanceof EntityEnclosingRequestInterface && $request->getBody()) { $request->getBody()->seek(0); } $multi = $event['curl_multi']; $multi->remove($request); $multi->add($request); } } } callback = $callback; $this->decision = (bool) $decision; $this->next = $next; } public function makesDecision() { return $this->decision; } protected function getDelay($retries, RequestInterface $request, Response $response = null, HttpException $e = null) { return call_user_func($this->callback, $retries, $request, $response, $e); } } delay = $delay; } public function makesDecision() { return false; } protected function getDelay($retries, RequestInterface $request, Response $response = null, HttpException $e = null) { return $this->delay; } } errorCodes[$e->getErrorNo()]) ? true : null; } } } isSuccessful()) { return false; } else { return isset($this->errorCodes[$response->getStatusCode()]) ? true : null; } } } } step = $step; } public function makesDecision() { return false; } protected function getDelay($retries, RequestInterface $request, Response $response = null, HttpException $e = null) { return $retries * $this->step; } } errorCodes[$response->getReasonPhrase()]) ? true : null; } } } max = $maxRetries; $this->next = $next; } public function makesDecision() { return true; } protected function getDelay($retries, RequestInterface $request, Response $response = null, HttpException $e = null) { return $retries < $this->max ? null : false; } } new DefaultCacheStorage($options)); } elseif ($options instanceof CacheStorageInterface) { $options = array('storage' => $options); } elseif ($options) { $options = array('storage' => new DefaultCacheStorage(CacheAdapterFactory::fromCache($options))); } elseif (!class_exists('Doctrine\Common\Cache\ArrayCache')) { // @codeCoverageIgnoreStart throw new InvalidArgumentException('No cache was provided and Doctrine is not installed'); // @codeCoverageIgnoreEnd } } $this->autoPurge = isset($options['auto_purge']) ? $options['auto_purge'] : false; // Add a cache storage if a cache adapter was provided $this->storage = isset($options['storage']) ? $options['storage'] : new DefaultCacheStorage(new DoctrineCacheAdapter(new ArrayCache())); if (!isset($options['can_cache'])) { $this->canCache = new DefaultCanCacheStrategy(); } else { $this->canCache = is_callable($options['can_cache']) ? new CallbackCanCacheStrategy($options['can_cache']) : $options['can_cache']; } // Use the provided revalidation strategy or the default $this->revalidation = isset($options['revalidation']) ? $options['revalidation'] : new DefaultRevalidation($this->storage, $this->canCache); } public static function getSubscribedEvents() { return array( 'request.before_send' => array('onRequestBeforeSend', -255), 'request.sent' => array('onRequestSent', 255), 'request.error' => array('onRequestError', 0), 'request.exception' => array('onRequestException', 0), ); } /** * Check if a response in cache will satisfy the request before sending * * @param Event $event */ public function onRequestBeforeSend(Event $event) { $request = $event['request']; $request->addHeader('Via', sprintf('%s GuzzleCache/%s', $request->getProtocolVersion(), Version::VERSION)); if (!$this->canCache->canCacheRequest($request)) { switch ($request->getMethod()) { case 'PURGE': $this->purge($request); $request->setResponse(new Response(200, array(), 'purged')); break; case 'PUT': case 'POST': case 'DELETE': case 'PATCH': if ($this->autoPurge) { $this->purge($request); } } return; } if ($response = $this->storage->fetch($request)) { $params = $request->getParams(); $params['cache.lookup'] = true; $response->setHeader( 'Age', time() - strtotime($response->getDate() ? : $response->getLastModified() ?: 'now') ); // Validate that the response satisfies the request if ($this->canResponseSatisfyRequest($request, $response)) { if (!isset($params['cache.hit'])) { $params['cache.hit'] = true; } $request->setResponse($response); } } } /** * If possible, store a response in cache after sending * * @param Event $event */ public function onRequestSent(Event $event) { $request = $event['request']; $response = $event['response']; if ($request->getParams()->get('cache.hit') === null && $this->canCache->canCacheRequest($request) && $this->canCache->canCacheResponse($response) ) { $this->storage->cache($request, $response); } $this->addResponseHeaders($request, $response); } /** * If possible, return a cache response on an error * * @param Event $event */ public function onRequestError(Event $event) { $request = $event['request']; if (!$this->canCache->canCacheRequest($request)) { return; } if ($response = $this->storage->fetch($request)) { $response->setHeader( 'Age', time() - strtotime($response->getLastModified() ? : $response->getDate() ?: 'now') ); if ($this->canResponseSatisfyFailedRequest($request, $response)) { $request->getParams()->set('cache.hit', 'error'); $this->addResponseHeaders($request, $response); $event['response'] = $response; $event->stopPropagation(); } } } /** * If possible, set a cache response on a cURL exception * * @param Event $event * * @return null */ public function onRequestException(Event $event) { if (!$event['exception'] instanceof CurlException) { return; } $request = $event['request']; if (!$this->canCache->canCacheRequest($request)) { return; } if ($response = $this->storage->fetch($request)) { $response->setHeader('Age', time() - strtotime($response->getDate() ? : 'now')); if (!$this->canResponseSatisfyFailedRequest($request, $response)) { return; } $request->getParams()->set('cache.hit', 'error'); $request->setResponse($response); $this->addResponseHeaders($request, $response); $event->stopPropagation(); } } /** * Check if a cache response satisfies a request's caching constraints * * @param RequestInterface $request Request to validate * @param Response $response Response to validate * * @return bool */ public function canResponseSatisfyRequest(RequestInterface $request, Response $response) { $responseAge = $response->calculateAge(); $reqc = $request->getHeader('Cache-Control'); $resc = $response->getHeader('Cache-Control'); // Check the request's max-age header against the age of the response if ($reqc && $reqc->hasDirective('max-age') && $responseAge > $reqc->getDirective('max-age')) { return false; } // Check the response's max-age header if ($response->isFresh() === false) { $maxStale = $reqc ? $reqc->getDirective('max-stale') : null; if (null !== $maxStale) { if ($maxStale !== true && $response->getFreshness() < (-1 * $maxStale)) { return false; } } elseif ($resc && $resc->hasDirective('max-age') && $responseAge > $resc->getDirective('max-age') ) { return false; } } if ($this->revalidation->shouldRevalidate($request, $response)) { try { return $this->revalidation->revalidate($request, $response); } catch (CurlException $e) { $request->getParams()->set('cache.hit', 'error'); return $this->canResponseSatisfyFailedRequest($request, $response); } } return true; } /** * Check if a cache response satisfies a failed request's caching constraints * * @param RequestInterface $request Request to validate * @param Response $response Response to validate * * @return bool */ public function canResponseSatisfyFailedRequest(RequestInterface $request, Response $response) { $reqc = $request->getHeader('Cache-Control'); $resc = $response->getHeader('Cache-Control'); $requestStaleIfError = $reqc ? $reqc->getDirective('stale-if-error') : null; $responseStaleIfError = $resc ? $resc->getDirective('stale-if-error') : null; if (!$requestStaleIfError && !$responseStaleIfError) { return false; } if (is_numeric($requestStaleIfError) && $response->getAge() - $response->getMaxAge() > $requestStaleIfError) { return false; } if (is_numeric($responseStaleIfError) && $response->getAge() - $response->getMaxAge() > $responseStaleIfError) { return false; } return true; } /** * Purge all cache entries for a given URL * * @param string $url URL to purge */ public function purge($url) { // BC compatibility with previous version that accepted a Request object $url = $url instanceof RequestInterface ? $url->getUrl() : $url; $this->storage->purge($url); } /** * Add the plugin's headers to a response * * @param RequestInterface $request Request * @param Response $response Response to add headers to */ protected function addResponseHeaders(RequestInterface $request, Response $response) { $params = $request->getParams(); $response->setHeader('Via', sprintf('%s GuzzleCache/%s', $request->getProtocolVersion(), Version::VERSION)); $lookup = ($params['cache.lookup'] === true ? 'HIT' : 'MISS') . ' from GuzzleCache'; if ($header = $response->getHeader('X-Cache-Lookup')) { // Don't add duplicates $values = $header->toArray(); $values[] = $lookup; $response->setHeader('X-Cache-Lookup', array_unique($values)); } else { $response->setHeader('X-Cache-Lookup', $lookup); } if ($params['cache.hit'] === true) { $xcache = 'HIT from GuzzleCache'; } elseif ($params['cache.hit'] == 'error') { $xcache = 'HIT_ERROR from GuzzleCache'; } else { $xcache = 'MISS from GuzzleCache'; } if ($header = $response->getHeader('X-Cache')) { // Don't add duplicates $values = $header->toArray(); $values[] = $xcache; $response->setHeader('X-Cache', array_unique($values)); } else { $response->setHeader('X-Cache', $xcache); } if ($response->isFresh() === false) { $response->addHeader('Warning', sprintf('110 GuzzleCache/%s "Response is stale"', Version::VERSION)); if ($params['cache.hit'] === 'error') { $response->addHeader('Warning', sprintf('111 GuzzleCache/%s "Revalidation failed"', Version::VERSION)); } } } } requestCallback = $requestCallback; $this->responseCallback = $responseCallback; } public function canCacheRequest(RequestInterface $request) { return $this->requestCallback ? call_user_func($this->requestCallback, $request) : parent::canCacheRequest($request); } public function canCacheResponse(Response $response) { return $this->responseCallback ? call_user_func($this->responseCallback, $response) : parent::canCacheResponse($response); } } getParams()->get(self::CACHE_KEY); if (!$key) { $cloned = clone $request; $cloned->removeHeader('Cache-Control'); // Check to see how and if the key should be filtered foreach (explode(';', $request->getParams()->get(self::CACHE_KEY_FILTER)) as $part) { $pieces = array_map('trim', explode('=', $part)); if (isset($pieces[1])) { foreach (array_map('trim', explode(',', $pieces[1])) as $remove) { if ($pieces[0] == 'header') { $cloned->removeHeader($remove); } elseif ($pieces[0] == 'query') { $cloned->getQuery()->remove($remove); } } } } $raw = (string) $cloned; $key = 'GZ' . md5($raw); $request->getParams()->set(self::CACHE_KEY, $key)->set(self::CACHE_KEY_RAW, $raw); } return $key; } } cache = CacheAdapterFactory::fromCache($cache); $this->defaultTtl = $defaultTtl; $this->keyPrefix = $keyPrefix; } public function cache(RequestInterface $request, Response $response) { $currentTime = time(); $ttl = $request->getParams()->get('cache.override_ttl') ?: $response->getMaxAge() ?: $this->defaultTtl; if ($cacheControl = $response->getHeader('Cache-Control')) { $stale = $cacheControl->getDirective('stale-if-error'); $ttl += $stale == true ? $ttl : $stale; } // Determine which manifest key should be used $key = $this->getCacheKey($request); $persistedRequest = $this->persistHeaders($request); $entries = array(); if ($manifest = $this->cache->fetch($key)) { // Determine which cache entries should still be in the cache $vary = $response->getVary(); foreach (unserialize($manifest) as $entry) { // Check if the entry is expired if ($entry[4] < $currentTime) { continue; } $entry[1]['vary'] = isset($entry[1]['vary']) ? $entry[1]['vary'] : ''; if ($vary != $entry[1]['vary'] || !$this->requestsMatch($vary, $entry[0], $persistedRequest)) { $entries[] = $entry; } } } // Persist the response body if needed $bodyDigest = null; if ($response->getBody() && $response->getBody()->getContentLength() > 0) { $bodyDigest = $this->getBodyKey($request->getUrl(), $response->getBody()); $this->cache->save($bodyDigest, (string) $response->getBody(), $ttl); } array_unshift($entries, array( $persistedRequest, $this->persistHeaders($response), $response->getStatusCode(), $bodyDigest, $currentTime + $ttl )); $this->cache->save($key, serialize($entries)); } public function delete(RequestInterface $request) { $key = $this->getCacheKey($request); if ($entries = $this->cache->fetch($key)) { // Delete each cached body foreach (unserialize($entries) as $entry) { if ($entry[3]) { $this->cache->delete($entry[3]); } } $this->cache->delete($key); } } public function purge($url) { foreach (array('GET', 'HEAD', 'POST', 'PUT', 'DELETE') as $method) { $this->delete(new Request($method, $url)); } } public function fetch(RequestInterface $request) { $key = $this->getCacheKey($request); if (!($entries = $this->cache->fetch($key))) { return null; } $match = null; $headers = $this->persistHeaders($request); $entries = unserialize($entries); foreach ($entries as $index => $entry) { if ($this->requestsMatch(isset($entry[1]['vary']) ? $entry[1]['vary'] : '', $headers, $entry[0])) { $match = $entry; break; } } if (!$match) { return null; } // Ensure that the response is not expired $response = null; if ($match[4] < time()) { $response = -1; } else { $response = new Response($match[2], $match[1]); if ($match[3]) { if ($body = $this->cache->fetch($match[3])) { $response->setBody($body); } else { // The response is not valid because the body was somehow deleted $response = -1; } } } if ($response === -1) { // Remove the entry from the metadata and update the cache unset($entries[$index]); if ($entries) { $this->cache->save($key, serialize($entries)); } else { $this->cache->delete($key); } return null; } return $response; } /** * Hash a request URL into a string that returns cache metadata * * @param RequestInterface $request * * @return string */ protected function getCacheKey(RequestInterface $request) { // Allow cache.key_filter to trim down the URL cache key by removing generate query string values (e.g. auth) if ($filter = $request->getParams()->get('cache.key_filter')) { $url = $request->getUrl(true); foreach (explode(',', $filter) as $remove) { $url->getQuery()->remove(trim($remove)); } } else { $url = $request->getUrl(); } return $this->keyPrefix . md5($request->getMethod() . ' ' . $url); } /** * Create a cache key for a response's body * * @param string $url URL of the entry * @param EntityBodyInterface $body Response body * * @return string */ protected function getBodyKey($url, EntityBodyInterface $body) { return $this->keyPrefix . md5($url) . $body->getContentMd5(); } /** * Determines whether two Request HTTP header sets are non-varying * * @param string $vary Response vary header * @param array $r1 HTTP header array * @param array $r2 HTTP header array * * @return bool */ private function requestsMatch($vary, $r1, $r2) { if ($vary) { foreach (explode(',', $vary) as $header) { $key = trim(strtolower($header)); $v1 = isset($r1[$key]) ? $r1[$key] : null; $v2 = isset($r2[$key]) ? $r2[$key] : null; if ($v1 !== $v2) { return false; } } } return true; } /** * Creates an array of cacheable and normalized message headers * * @param MessageInterface $message * * @return array */ private function persistHeaders(MessageInterface $message) { // Headers are excluded from the caching (see RFC 2616:13.5.1) static $noCache = array( 'age' => true, 'connection' => true, 'keep-alive' => true, 'proxy-authenticate' => true, 'proxy-authorization' => true, 'te' => true, 'trailers' => true, 'transfer-encoding' => true, 'upgrade' => true, 'set-cookie' => true, 'set-cookie2' => true ); // Clone the response to not destroy any necessary headers when caching $headers = $message->getHeaders()->getAll(); $headers = array_diff_key($headers, $noCache); // Cast the headers to a string $headers = array_map(function ($h) { return (string) $h; }, $headers); return $headers; } } getMethod() != RequestInterface::GET && $request->getMethod() != RequestInterface::HEAD) { return false; } // Never cache requests when using no-store if ($request->hasHeader('Cache-Control') && $request->getHeader('Cache-Control')->hasDirective('no-store')) { return false; } return true; } public function canCacheResponse(Response $response) { return $response->isSuccessful() && $response->canCache(); } } storage = $cache; $this->canCache = $canCache ?: new DefaultCanCacheStrategy(); } public function revalidate(RequestInterface $request, Response $response) { try { $revalidate = $this->createRevalidationRequest($request, $response); $validateResponse = $revalidate->send(); if ($validateResponse->getStatusCode() == 200) { return $this->handle200Response($request, $validateResponse); } elseif ($validateResponse->getStatusCode() == 304) { return $this->handle304Response($request, $validateResponse, $response); } } catch (BadResponseException $e) { $this->handleBadResponse($e); } // Other exceptions encountered in the revalidation request are ignored // in hopes that sending a request to the origin server will fix it return false; } public function shouldRevalidate(RequestInterface $request, Response $response) { if ($request->getMethod() != RequestInterface::GET) { return false; } $reqCache = $request->getHeader('Cache-Control'); $resCache = $response->getHeader('Cache-Control'); $revalidate = $request->getHeader('Pragma') == 'no-cache' || ($reqCache && ($reqCache->hasDirective('no-cache') || $reqCache->hasDirective('must-revalidate'))) || ($resCache && ($resCache->hasDirective('no-cache') || $resCache->hasDirective('must-revalidate'))); // Use the strong ETag validator if available and the response contains no Cache-Control directive if (!$revalidate && !$resCache && $response->hasHeader('ETag')) { $revalidate = true; } return $revalidate; } /** * Handles a bad response when attempting to revalidate * * @param BadResponseException $e Exception encountered * * @throws BadResponseException */ protected function handleBadResponse(BadResponseException $e) { // 404 errors mean the resource no longer exists, so remove from // cache, and prevent an additional request by throwing the exception if ($e->getResponse()->getStatusCode() == 404) { $this->storage->delete($e->getRequest()); throw $e; } } /** * Creates a request to use for revalidation * * @param RequestInterface $request Request * @param Response $response Response to revalidate * * @return RequestInterface returns a revalidation request */ protected function createRevalidationRequest(RequestInterface $request, Response $response) { $revalidate = clone $request; $revalidate->removeHeader('Pragma') ->removeHeader('Cache-Control') ->setHeader('If-Modified-Since', $response->getLastModified() ?: $response->getDate()); if ($response->getEtag()) { $revalidate->setHeader('If-None-Match', $response->getEtag()); } // Remove any cache plugins that might be on the request to prevent infinite recursive revalidations $dispatcher = $revalidate->getEventDispatcher(); foreach ($dispatcher->getListeners() as $eventName => $listeners) { foreach ($listeners as $listener) { if (is_array($listener) && $listener[0] instanceof CachePlugin) { $dispatcher->removeListener($eventName, $listener); } } } return $revalidate; } /** * Handles a 200 response response from revalidating. The server does not support validation, so use this response. * * @param RequestInterface $request Request that was sent * @param Response $validateResponse Response received * * @return bool Returns true if valid, false if invalid */ protected function handle200Response(RequestInterface $request, Response $validateResponse) { $request->setResponse($validateResponse); if ($this->canCache->canCacheResponse($validateResponse)) { $this->storage->cache($request, $validateResponse); } return false; } /** * Handle a 304 response and ensure that it is still valid * * @param RequestInterface $request Request that was sent * @param Response $validateResponse Response received * @param Response $response Original cached response * * @return bool Returns true if valid, false if invalid */ protected function handle304Response(RequestInterface $request, Response $validateResponse, Response $response) { static $replaceHeaders = array('Date', 'Expires', 'Cache-Control', 'ETag', 'Last-Modified'); // Make sure that this response has the same ETag if ($validateResponse->getEtag() != $response->getEtag()) { return false; } // Replace cached headers with any of these headers from the // origin server that might be more up to date $modified = false; foreach ($replaceHeaders as $name) { if ($validateResponse->hasHeader($name)) { $modified = true; $response->setHeader($name, $validateResponse->getHeader($name)); } } // Store the updated response in cache if ($modified && $this->canCache->canCacheResponse($response)) { $this->storage->cache($request, $response); } return true; } } '', 'value' => '', 'domain' => '', 'path' => '/', 'expires' => null, 'max_age' => 0, 'comment' => null, 'comment_url' => null, 'port' => array(), 'version' => null, 'secure' => false, 'discard' => false, 'http_only' => false ); $this->data = array_merge($defaults, $data); // Extract the expires value and turn it into a UNIX timestamp if needed if (!$this->getExpires() && $this->getMaxAge()) { // Calculate the expires date $this->setExpires(time() + (int) $this->getMaxAge()); } elseif ($this->getExpires() && !is_numeric($this->getExpires())) { $this->setExpires(strtotime($this->getExpires())); } } /** * Get the cookie as an array * * @return array */ public function toArray() { return $this->data; } /** * Get the cookie name * * @return string */ public function getName() { return $this->data['name']; } /** * Set the cookie name * * @param string $name Cookie name * * @return Cookie */ public function setName($name) { return $this->setData('name', $name); } /** * Get the cookie value * * @return string */ public function getValue() { return $this->data['value']; } /** * Set the cookie value * * @param string $value Cookie value * * @return Cookie */ public function setValue($value) { return $this->setData('value', $value); } /** * Get the domain * * @return string|null */ public function getDomain() { return $this->data['domain']; } /** * Set the domain of the cookie * * @param string $domain * * @return Cookie */ public function setDomain($domain) { return $this->setData('domain', $domain); } /** * Get the path * * @return string */ public function getPath() { return $this->data['path']; } /** * Set the path of the cookie * * @param string $path Path of the cookie * * @return Cookie */ public function setPath($path) { return $this->setData('path', $path); } /** * Maximum lifetime of the cookie in seconds * * @return int|null */ public function getMaxAge() { return $this->data['max_age']; } /** * Set the max-age of the cookie * * @param int $maxAge Max age of the cookie in seconds * * @return Cookie */ public function setMaxAge($maxAge) { return $this->setData('max_age', $maxAge); } /** * The UNIX timestamp when the cookie expires * * @return mixed */ public function getExpires() { return $this->data['expires']; } /** * Set the unix timestamp for which the cookie will expire * * @param int $timestamp Unix timestamp * * @return Cookie */ public function setExpires($timestamp) { return $this->setData('expires', $timestamp); } /** * Version of the cookie specification. RFC 2965 is 1 * * @return mixed */ public function getVersion() { return $this->data['version']; } /** * Set the cookie version * * @param string|int $version Version to set * * @return Cookie */ public function setVersion($version) { return $this->setData('version', $version); } /** * Get whether or not this is a secure cookie * * @return null|bool */ public function getSecure() { return $this->data['secure']; } /** * Set whether or not the cookie is secure * * @param bool $secure Set to true or false if secure * * @return Cookie */ public function setSecure($secure) { return $this->setData('secure', (bool) $secure); } /** * Get whether or not this is a session cookie * * @return null|bool */ public function getDiscard() { return $this->data['discard']; } /** * Set whether or not this is a session cookie * * @param bool $discard Set to true or false if this is a session cookie * * @return Cookie */ public function setDiscard($discard) { return $this->setData('discard', $discard); } /** * Get the comment * * @return string|null */ public function getComment() { return $this->data['comment']; } /** * Set the comment of the cookie * * @param string $comment Cookie comment * * @return Cookie */ public function setComment($comment) { return $this->setData('comment', $comment); } /** * Get the comment URL of the cookie * * @return string|null */ public function getCommentUrl() { return $this->data['comment_url']; } /** * Set the comment URL of the cookie * * @param string $commentUrl Cookie comment URL for more information * * @return Cookie */ public function setCommentUrl($commentUrl) { return $this->setData('comment_url', $commentUrl); } /** * Get an array of acceptable ports this cookie can be used with * * @return array */ public function getPorts() { return $this->data['port']; } /** * Set a list of acceptable ports this cookie can be used with * * @param array $ports Array of acceptable ports * * @return Cookie */ public function setPorts(array $ports) { return $this->setData('port', $ports); } /** * Get whether or not this is an HTTP only cookie * * @return bool */ public function getHttpOnly() { return $this->data['http_only']; } /** * Set whether or not this is an HTTP only cookie * * @param bool $httpOnly Set to true or false if this is HTTP only * * @return Cookie */ public function setHttpOnly($httpOnly) { return $this->setData('http_only', $httpOnly); } /** * Get an array of extra cookie data * * @return array */ public function getAttributes() { return $this->data['data']; } /** * Get a specific data point from the extra cookie data * * @param string $name Name of the data point to retrieve * * @return null|string */ public function getAttribute($name) { return array_key_exists($name, $this->data['data']) ? $this->data['data'][$name] : null; } /** * Set a cookie data attribute * * @param string $name Name of the attribute to set * @param string $value Value to set * * @return Cookie */ public function setAttribute($name, $value) { $this->data['data'][$name] = $value; return $this; } /** * Check if the cookie matches a path value * * @param string $path Path to check against * * @return bool */ public function matchesPath($path) { return !$this->getPath() || 0 === stripos($path, $this->getPath()); } /** * Check if the cookie matches a domain value * * @param string $domain Domain to check against * * @return bool */ public function matchesDomain($domain) { // Remove the leading '.' as per spec in RFC 6265: http://tools.ietf.org/html/rfc6265#section-5.2.3 $cookieDomain = ltrim($this->getDomain(), '.'); // Domain not set or exact match. if (!$cookieDomain || !strcasecmp($domain, $cookieDomain)) { return true; } // Matching the subdomain according to RFC 6265: http://tools.ietf.org/html/rfc6265#section-5.1.3 if (filter_var($domain, FILTER_VALIDATE_IP)) { return false; } return (bool) preg_match('/\.' . preg_quote($cookieDomain, '/') . '$/i', $domain); } /** * Check if the cookie is compatible with a specific port * * @param int $port Port to check * * @return bool */ public function matchesPort($port) { return count($this->getPorts()) == 0 || in_array($port, $this->getPorts()); } /** * Check if the cookie is expired * * @return bool */ public function isExpired() { return $this->getExpires() && time() > $this->getExpires(); } /** * Check if the cookie is valid according to RFC 6265 * * @return bool|string Returns true if valid or an error message if invalid */ public function validate() { // Names must not be empty, but can be 0 $name = $this->getName(); if (empty($name) && !is_numeric($name)) { return 'The cookie name must not be empty'; } // Check if any of the invalid characters are present in the cookie name if (strpbrk($name, self::getInvalidCharacters()) !== false) { return 'The cookie name must not contain invalid characters: ' . $name; } // Value must not be empty, but can be 0 $value = $this->getValue(); if (empty($value) && !is_numeric($value)) { return 'The cookie value must not be empty'; } // Domains must not be empty, but can be 0 // A "0" is not a valid internet domain, but may be used as server name in a private network $domain = $this->getDomain(); if (empty($domain) && !is_numeric($domain)) { return 'The cookie domain must not be empty'; } return true; } /** * Set a value and return the cookie object * * @param string $key Key to set * @param string $value Value to set * * @return Cookie */ private function setData($key, $value) { $this->data[$key] = $value; return $this; } } strictMode = $strictMode; } /** * Enable or disable strict mode on the cookie jar * * @param bool $strictMode Set to true to throw exceptions when invalid cookies are added. False to ignore them. * * @return self */ public function setStrictMode($strictMode) { $this->strictMode = $strictMode; } public function remove($domain = null, $path = null, $name = null) { $cookies = $this->all($domain, $path, $name, false, false); $this->cookies = array_filter($this->cookies, function (Cookie $cookie) use ($cookies) { return !in_array($cookie, $cookies, true); }); return $this; } public function removeTemporary() { $this->cookies = array_filter($this->cookies, function (Cookie $cookie) { return !$cookie->getDiscard() && $cookie->getExpires(); }); return $this; } public function removeExpired() { $currentTime = time(); $this->cookies = array_filter($this->cookies, function (Cookie $cookie) use ($currentTime) { return !$cookie->getExpires() || $currentTime < $cookie->getExpires(); }); return $this; } public function all($domain = null, $path = null, $name = null, $skipDiscardable = false, $skipExpired = true) { return array_values(array_filter($this->cookies, function (Cookie $cookie) use ( $domain, $path, $name, $skipDiscardable, $skipExpired ) { return false === (($name && $cookie->getName() != $name) || ($skipExpired && $cookie->isExpired()) || ($skipDiscardable && ($cookie->getDiscard() || !$cookie->getExpires())) || ($path && !$cookie->matchesPath($path)) || ($domain && !$cookie->matchesDomain($domain))); })); } public function add(Cookie $cookie) { // Only allow cookies with set and valid domain, name, value $result = $cookie->validate(); if ($result !== true) { if ($this->strictMode) { throw new InvalidCookieException($result); } else { return false; } } // Resolve conflicts with previously set cookies foreach ($this->cookies as $i => $c) { // Two cookies are identical, when their path, domain, port and name are identical if ($c->getPath() != $cookie->getPath() || $c->getDomain() != $cookie->getDomain() || $c->getPorts() != $cookie->getPorts() || $c->getName() != $cookie->getName() ) { continue; } // The previously set cookie is a discard cookie and this one is not so allow the new cookie to be set if (!$cookie->getDiscard() && $c->getDiscard()) { unset($this->cookies[$i]); continue; } // If the new cookie's expiration is further into the future, then replace the old cookie if ($cookie->getExpires() > $c->getExpires()) { unset($this->cookies[$i]); continue; } // If the value has changed, we better change it if ($cookie->getValue() !== $c->getValue()) { unset($this->cookies[$i]); continue; } // The cookie exists, so no need to continue return false; } $this->cookies[] = $cookie; return true; } /** * Serializes the cookie cookieJar * * @return string */ public function serialize() { // Only serialize long term cookies and unexpired cookies return json_encode(array_map(function (Cookie $cookie) { return $cookie->toArray(); }, $this->all(null, null, null, true, true))); } /** * Unserializes the cookie cookieJar */ public function unserialize($data) { $data = json_decode($data, true); if (empty($data)) { $this->cookies = array(); } else { $this->cookies = array_map(function (array $cookie) { return new Cookie($cookie); }, $data); } } /** * Returns the total number of stored cookies * * @return int */ public function count() { return count($this->cookies); } /** * Returns an iterator * * @return \ArrayIterator */ public function getIterator() { return new \ArrayIterator($this->cookies); } public function addCookiesFromResponse(Response $response, RequestInterface $request = null) { if ($cookieHeader = $response->getHeader('Set-Cookie')) { $parser = ParserRegistry::getInstance()->getParser('cookie'); foreach ($cookieHeader as $cookie) { if ($parsed = $request ? $parser->parseCookie($cookie, $request->getHost(), $request->getPath()) : $parser->parseCookie($cookie) ) { // Break up cookie v2 into multiple cookies foreach ($parsed['cookies'] as $key => $value) { $row = $parsed; $row['name'] = $key; $row['value'] = $value; unset($row['cookies']); $this->add(new Cookie($row)); } } } } } public function getMatchingCookies(RequestInterface $request) { // Find cookies that match this request $cookies = $this->all($request->getHost(), $request->getPath()); // Remove ineligible cookies foreach ($cookies as $index => $cookie) { if (!$cookie->matchesPort($request->getPort()) || ($cookie->getSecure() && $request->getScheme() != 'https')) { unset($cookies[$index]); } }; return $cookies; } } filename = $cookieFile; $this->load(); } /** * Saves the file when shutting down */ public function __destruct() { $this->persist(); } /** * Save the contents of the data array to the file * * @throws RuntimeException if the file cannot be found or created */ protected function persist() { if (false === file_put_contents($this->filename, $this->serialize())) { // @codeCoverageIgnoreStart throw new RuntimeException('Unable to open file ' . $this->filename); // @codeCoverageIgnoreEnd } } /** * Load the contents of the json formatted file into the data array and discard any unsaved state */ protected function load() { $json = file_get_contents($this->filename); if (false === $json) { // @codeCoverageIgnoreStart throw new RuntimeException('Unable to open file ' . $this->filename); // @codeCoverageIgnoreEnd } $this->unserialize($json); $this->cookies = $this->cookies ?: array(); } } cookieJar = $cookieJar ?: new ArrayCookieJar(); } public static function getSubscribedEvents() { return array( 'request.before_send' => array('onRequestBeforeSend', 125), 'request.sent' => array('onRequestSent', 125) ); } /** * Get the cookie cookieJar * * @return CookieJarInterface */ public function getCookieJar() { return $this->cookieJar; } /** * Add cookies before a request is sent * * @param Event $event */ public function onRequestBeforeSend(Event $event) { $request = $event['request']; if (!$request->getParams()->get('cookies.disable')) { $request->removeHeader('Cookie'); // Find cookies that match this request foreach ($this->cookieJar->getMatchingCookies($request) as $cookie) { $request->addCookie($cookie->getName(), $cookie->getValue()); } } } /** * Extract cookies from a sent request * * @param Event $event */ public function onRequestSent(Event $event) { $this->cookieJar->addCookiesFromResponse($event['response'], $event['request']); } } getConfig()->setPath('request.options/auth', array('user', 'pass', 'Basic|Digest'); */ class CurlAuthPlugin implements EventSubscriberInterface { private $username; private $password; private $scheme; /** * @param string $username HTTP basic auth username * @param string $password Password * @param int $scheme Curl auth scheme */ public function __construct($username, $password, $scheme=CURLAUTH_BASIC) { Version::warn(__CLASS__ . " is deprecated. Use \$client->getConfig()->setPath('request.options/auth', array('user', 'pass', 'Basic|Digest');"); $this->username = $username; $this->password = $password; $this->scheme = $scheme; } public static function getSubscribedEvents() { return array('client.create_request' => array('onRequestCreate', 255)); } /** * Add basic auth * * @param Event $event */ public function onRequestCreate(Event $event) { $event['request']->setAuth($this->username, $this->password, $this->scheme); } } array('onCommandBeforeSend', -1)); } /** * Adds a listener to requests before they sent from a command * * @param Event $event Event emitted */ public function onCommandBeforeSend(Event $event) { $command = $event['command']; if ($operation = $command->getOperation()) { if ($operation->getErrorResponses()) { $request = $command->getRequest(); $request->getEventDispatcher() ->addListener('request.complete', $this->getErrorClosure($request, $command, $operation)); } } } /** * @param RequestInterface $request Request that received an error * @param CommandInterface $command Command that created the request * @param Operation $operation Operation that defines the request and errors * * @return \Closure Returns a closure * @throws ErrorResponseException */ protected function getErrorClosure(RequestInterface $request, CommandInterface $command, Operation $operation) { return function (Event $event) use ($request, $command, $operation) { $response = $event['response']; foreach ($operation->getErrorResponses() as $error) { if (!isset($error['class'])) { continue; } if (isset($error['code']) && $response->getStatusCode() != $error['code']) { continue; } if (isset($error['reason']) && $response->getReasonPhrase() != $error['reason']) { continue; } $className = $error['class']; $errorClassInterface = __NAMESPACE__ . '\\ErrorResponseExceptionInterface'; if (!class_exists($className)) { throw new ErrorResponseException("{$className} does not exist"); } elseif (!is_subclass_of($className, $errorClassInterface)) { throw new ErrorResponseException("{$className} must implement {$errorClassInterface}"); } throw $className::fromCommand($command, $response); } }; } } array('onRequestSent', 9999)); } /** * Convert to a string that contains all request and response headers * * @return string */ public function __toString() { $lines = array(); foreach ($this->transactions as $entry) { $response = isset($entry['response']) ? $entry['response'] : ''; $lines[] = '> ' . trim($entry['request']) . "\n\n< " . trim($response) . "\n"; } return implode("\n", $lines); } /** * Add a request to the history * * @param RequestInterface $request Request to add * @param Response $response Response of the request * * @return HistoryPlugin */ public function add(RequestInterface $request, Response $response = null) { if (!$response && $request->getResponse()) { $response = $request->getResponse(); } $this->transactions[] = array('request' => $request, 'response' => $response); if (count($this->transactions) > $this->getlimit()) { array_shift($this->transactions); } return $this; } /** * Set the max number of requests to store * * @param int $limit Limit * * @return HistoryPlugin */ public function setLimit($limit) { $this->limit = (int) $limit; return $this; } /** * Get the request limit * * @return int */ public function getLimit() { return $this->limit; } /** * Get all of the raw transactions in the form of an array of associative arrays containing * 'request' and 'response' keys. * * @return array */ public function getAll() { return $this->transactions; } /** * Get the requests in the history * * @return \ArrayIterator */ public function getIterator() { // Return an iterator just like the old iteration of the HistoryPlugin for BC compatibility (use getAll()) return new \ArrayIterator(array_map(function ($entry) { $entry['request']->getParams()->set('actual_response', $entry['response']); return $entry['request']; }, $this->transactions)); } /** * Get the number of requests in the history * * @return int */ public function count() { return count($this->transactions); } /** * Get the last request sent * * @return RequestInterface */ public function getLastRequest() { $last = end($this->transactions); return $last['request']; } /** * Get the last response in the history * * @return Response|null */ public function getLastResponse() { $last = end($this->transactions); return isset($last['response']) ? $last['response'] : null; } /** * Clears the history * * @return HistoryPlugin */ public function clear() { $this->transactions = array(); return $this; } public function onRequestSent(Event $event) { $this->add($event['request'], $event['response']); } } logAdapter = $logAdapter; $this->formatter = $formatter instanceof MessageFormatter ? $formatter : new MessageFormatter($formatter); $this->wireBodies = $wireBodies; } /** * Get a log plugin that outputs full request, response, and curl error information to stderr * * @param bool $wireBodies Set to false to disable request/response body output when they use are not repeatable * @param resource $stream Stream to write to when logging. Defaults to STDERR when it is available * * @return self */ public static function getDebugPlugin($wireBodies = true, $stream = null) { if ($stream === null) { if (defined('STDERR')) { $stream = STDERR; } else { $stream = fopen('php://output', 'w'); } } return new self(new ClosureLogAdapter(function ($m) use ($stream) { fwrite($stream, $m . PHP_EOL); }), "# Request:\n{request}\n\n# Response:\n{response}\n\n# Errors: {curl_code} {curl_error}", $wireBodies); } public static function getSubscribedEvents() { return array( 'curl.callback.write' => array('onCurlWrite', 255), 'curl.callback.read' => array('onCurlRead', 255), 'request.before_send' => array('onRequestBeforeSend', 255), 'request.sent' => array('onRequestSent', 255) ); } /** * Event triggered when curl data is read from a request * * @param Event $event */ public function onCurlRead(Event $event) { // Stream the request body to the log if the body is not repeatable if ($wire = $event['request']->getParams()->get('request_wire')) { $wire->write($event['read']); } } /** * Event triggered when curl data is written to a response * * @param Event $event */ public function onCurlWrite(Event $event) { // Stream the response body to the log if the body is not repeatable if ($wire = $event['request']->getParams()->get('response_wire')) { $wire->write($event['write']); } } /** * Called before a request is sent * * @param Event $event */ public function onRequestBeforeSend(Event $event) { if ($this->wireBodies) { $request = $event['request']; // Ensure that curl IO events are emitted $request->getCurlOptions()->set('emit_io', true); // We need to make special handling for content wiring and non-repeatable streams. if ($request instanceof EntityEnclosingRequestInterface && $request->getBody() && (!$request->getBody()->isSeekable() || !$request->getBody()->isReadable()) ) { // The body of the request cannot be recalled so logging the body will require us to buffer it $request->getParams()->set('request_wire', EntityBody::factory()); } if (!$request->getResponseBody()->isRepeatable()) { // The body of the response cannot be recalled so logging the body will require us to buffer it $request->getParams()->set('response_wire', EntityBody::factory()); } } } /** * Triggers the actual log write when a request completes * * @param Event $event */ public function onRequestSent(Event $event) { $request = $event['request']; $response = $event['response']; $handle = $event['handle']; if ($wire = $request->getParams()->get('request_wire')) { $request = clone $request; $request->setBody($wire); } if ($wire = $request->getParams()->get('response_wire')) { $response = clone $response; $response->setBody($wire); } // Send the log message to the adapter, adding a category and host $priority = $response && $response->isError() ? LOG_ERR : LOG_DEBUG; $message = $this->formatter->format($request, $response, $handle); $this->logAdapter->log($message, $priority, array( 'request' => $request, 'response' => $response, 'handle' => $handle )); } } contentMd5Param = $contentMd5Param; $this->validateMd5Param = $validateMd5Param; } public static function getSubscribedEvents() { return array('command.before_send' => array('onCommandBeforeSend', -255)); } public function onCommandBeforeSend(Event $event) { $command = $event['command']; $request = $command->getRequest(); // Only add an MD5 is there is a MD5 option on the operation and it has a payload if ($request instanceof EntityEnclosingRequestInterface && $request->getBody() && $command->getOperation()->hasParam($this->contentMd5Param)) { // Check if an MD5 checksum value should be passed along to the request if ($command[$this->contentMd5Param] === true) { if (false !== ($md5 = $request->getBody()->getContentMd5(true, true))) { $request->setHeader('Content-MD5', $md5); } } } // Check if MD5 validation should be used with the response if ($command[$this->validateMd5Param] === true) { $request->addSubscriber(new Md5ValidatorPlugin(true, false)); } } } contentLengthCutoff = $contentLengthCutoff; $this->contentEncoded = $contentEncoded; } public static function getSubscribedEvents() { return array('request.complete' => array('onRequestComplete', 255)); } /** * {@inheritdoc} * @throws UnexpectedValueException */ public function onRequestComplete(Event $event) { $response = $event['response']; if (!$contentMd5 = $response->getContentMd5()) { return; } $contentEncoding = $response->getContentEncoding(); if ($contentEncoding && !$this->contentEncoded) { return false; } // Make sure that the size of the request is under the cutoff size if ($this->contentLengthCutoff) { $size = $response->getContentLength() ?: $response->getBody()->getSize(); if (!$size || $size > $this->contentLengthCutoff) { return; } } if (!$contentEncoding) { $hash = $response->getBody()->getContentMd5(); } elseif ($contentEncoding == 'gzip') { $response->getBody()->compress('zlib.deflate'); $hash = $response->getBody()->getContentMd5(); $response->getBody()->uncompress(); } elseif ($contentEncoding == 'compress') { $response->getBody()->compress('bzip2.compress'); $hash = $response->getBody()->getContentMd5(); $response->getBody()->uncompress(); } else { return; } if ($contentMd5 !== $hash) { throw new UnexpectedValueException( "The response entity body may have been modified over the wire. The Content-MD5 " . "received ({$contentMd5}) did not match the calculated MD5 hash ({$hash})." ); } } } readBodies = $readBodies; $this->temporary = $temporary; if ($items) { foreach ($items as $item) { if ($item instanceof \Exception) { $this->addException($item); } else { $this->addResponse($item); } } } } public static function getSubscribedEvents() { // Use a number lower than the CachePlugin return array('request.before_send' => array('onRequestBeforeSend', -999)); } public static function getAllEvents() { return array('mock.request'); } /** * Get a mock response from a file * * @param string $path File to retrieve a mock response from * * @return Response * @throws InvalidArgumentException if the file is not found */ public static function getMockFile($path) { if (!file_exists($path)) { throw new InvalidArgumentException('Unable to open mock file: ' . $path); } return Response::fromMessage(file_get_contents($path)); } /** * Set whether or not to consume the entity body of a request when a mock * response is used * * @param bool $readBodies Set to true to read and consume entity bodies * * @return self */ public function readBodies($readBodies) { $this->readBodies = $readBodies; return $this; } /** * Returns the number of remaining mock responses * * @return int */ public function count() { return count($this->queue); } /** * Add a response to the end of the queue * * @param string|Response $response Response object or path to response file * * @return MockPlugin * @throws InvalidArgumentException if a string or Response is not passed */ public function addResponse($response) { if (!($response instanceof Response)) { if (!is_string($response)) { throw new InvalidArgumentException('Invalid response'); } $response = self::getMockFile($response); } $this->queue[] = $response; return $this; } /** * Add an exception to the end of the queue * * @param CurlException $e Exception to throw when the request is executed * * @return MockPlugin */ public function addException(CurlException $e) { $this->queue[] = $e; return $this; } /** * Clear the queue * * @return MockPlugin */ public function clearQueue() { $this->queue = array(); return $this; } /** * Returns an array of mock responses remaining in the queue * * @return array */ public function getQueue() { return $this->queue; } /** * Check if this is a temporary plugin * * @return bool */ public function isTemporary() { return $this->temporary; } /** * Get a response from the front of the list and add it to a request * * @param RequestInterface $request Request to mock * * @return self * @throws CurlException When request.send is called and an exception is queued */ public function dequeue(RequestInterface $request) { $this->dispatch('mock.request', array('plugin' => $this, 'request' => $request)); $item = array_shift($this->queue); if ($item instanceof Response) { if ($this->readBodies && $request instanceof EntityEnclosingRequestInterface) { $request->getEventDispatcher()->addListener('request.sent', $f = function (Event $event) use (&$f) { while ($data = $event['request']->getBody()->read(8096)); // Remove the listener after one-time use $event['request']->getEventDispatcher()->removeListener('request.sent', $f); }); } $request->setResponse($item); } elseif ($item instanceof CurlException) { // Emulates exceptions encountered while transferring requests $item->setRequest($request); $state = $request->setState(RequestInterface::STATE_ERROR, array('exception' => $item)); // Only throw if the exception wasn't handled if ($state == RequestInterface::STATE_ERROR) { throw $item; } } return $this; } /** * Clear the array of received requests */ public function flush() { $this->received = array(); } /** * Get an array of requests that were mocked by this plugin * * @return array */ public function getReceivedRequests() { return $this->received; } /** * Called when a request is about to be sent * * @param Event $event */ public function onRequestBeforeSend(Event $event) { if ($this->queue) { $request = $event['request']; $this->received[] = $request; // Detach the filter from the client so it's a one-time use if ($this->temporary && count($this->queue) == 1 && $request->getClient()) { $request->getClient()->getEventDispatcher()->removeSubscriber($this); } $this->dequeue($request); } } } config = Collection::fromConfig($config, array( 'version' => '1.0', 'request_method' => self::REQUEST_METHOD_HEADER, 'consumer_key' => 'anonymous', 'consumer_secret' => 'anonymous', 'signature_method' => 'HMAC-SHA1', 'signature_callback' => function($stringToSign, $key) { return hash_hmac('sha1', $stringToSign, $key, true); } ), array( 'signature_method', 'signature_callback', 'version', 'consumer_key', 'consumer_secret' )); } public static function getSubscribedEvents() { return array( 'request.before_send' => array('onRequestBeforeSend', -1000) ); } /** * Request before-send event handler * * @param Event $event Event received * @return array * @throws \InvalidArgumentException */ public function onRequestBeforeSend(Event $event) { $timestamp = $this->getTimestamp($event); $request = $event['request']; $nonce = $this->generateNonce($request); $authorizationParams = $this->getOauthParams($timestamp, $nonce); $authorizationParams['oauth_signature'] = $this->getSignature($request, $timestamp, $nonce); switch ($this->config['request_method']) { case self::REQUEST_METHOD_HEADER: $request->setHeader( 'Authorization', $this->buildAuthorizationHeader($authorizationParams) ); break; case self::REQUEST_METHOD_QUERY: foreach ($authorizationParams as $key => $value) { $request->getQuery()->set($key, $value); } break; default: throw new \InvalidArgumentException(sprintf( 'Invalid consumer method "%s"', $this->config['request_method'] )); } return $authorizationParams; } /** * Builds the Authorization header for a request * * @param array $authorizationParams Associative array of authorization parameters * * @return string */ private function buildAuthorizationHeader($authorizationParams) { $authorizationString = 'OAuth '; foreach ($authorizationParams as $key => $val) { if ($val) { $authorizationString .= $key . '="' . urlencode($val) . '", '; } } return substr($authorizationString, 0, -2); } /** * Calculate signature for request * * @param RequestInterface $request Request to generate a signature for * @param integer $timestamp Timestamp to use for nonce * @param string $nonce * * @return string */ public function getSignature(RequestInterface $request, $timestamp, $nonce) { $string = $this->getStringToSign($request, $timestamp, $nonce); $key = urlencode($this->config['consumer_secret']) . '&' . urlencode($this->config['token_secret']); return base64_encode(call_user_func($this->config['signature_callback'], $string, $key)); } /** * Calculate string to sign * * @param RequestInterface $request Request to generate a signature for * @param int $timestamp Timestamp to use for nonce * @param string $nonce * * @return string */ public function getStringToSign(RequestInterface $request, $timestamp, $nonce) { $params = $this->getParamsToSign($request, $timestamp, $nonce); // Convert booleans to strings. $params = $this->prepareParameters($params); // Build signing string from combined params $parameterString = new QueryString($params); $url = Url::factory($request->getUrl())->setQuery('')->setFragment(null); return strtoupper($request->getMethod()) . '&' . rawurlencode($url) . '&' . rawurlencode((string) $parameterString); } /** * Get the oauth parameters as named by the oauth spec * * @param $timestamp * @param $nonce * @return Collection */ protected function getOauthParams($timestamp, $nonce) { $params = new Collection(array( 'oauth_consumer_key' => $this->config['consumer_key'], 'oauth_nonce' => $nonce, 'oauth_signature_method' => $this->config['signature_method'], 'oauth_timestamp' => $timestamp, )); // Optional parameters should not be set if they have not been set in the config as // the parameter may be considered invalid by the Oauth service. $optionalParams = array( 'callback' => 'oauth_callback', 'token' => 'oauth_token', 'verifier' => 'oauth_verifier', 'version' => 'oauth_version' ); foreach ($optionalParams as $optionName => $oauthName) { if (isset($this->config[$optionName]) == true) { $params[$oauthName] = $this->config[$optionName]; } } return $params; } /** * Get all of the parameters required to sign a request including: * * The oauth params * * The request GET params * * The params passed in the POST body (with a content-type of application/x-www-form-urlencoded) * * @param RequestInterface $request Request to generate a signature for * @param integer $timestamp Timestamp to use for nonce * @param string $nonce * * @return array */ public function getParamsToSign(RequestInterface $request, $timestamp, $nonce) { $params = $this->getOauthParams($timestamp, $nonce); // Add query string parameters $params->merge($request->getQuery()); // Add POST fields to signing string if required if ($this->shouldPostFieldsBeSigned($request)) { $params->merge($request->getPostFields()); } // Sort params $params = $params->toArray(); ksort($params); return $params; } /** * Decide whether the post fields should be added to the base string that Oauth signs. * This implementation is correct. Non-conformant APIs may require that this method be * overwritten e.g. the Flickr API incorrectly adds the post fields when the Content-Type * is 'application/x-www-form-urlencoded' * * @param $request * @return bool Whether the post fields should be signed or not */ public function shouldPostFieldsBeSigned($request) { if (!$this->config->get('disable_post_params') && $request instanceof EntityEnclosingRequestInterface && false !== strpos($request->getHeader('Content-Type'), 'application/x-www-form-urlencoded')) { return true; } return false; } /** * Returns a Nonce Based on the unique id and URL. This will allow for multiple requests in parallel with the same * exact timestamp to use separate nonce's. * * @param RequestInterface $request Request to generate a nonce for * * @return string */ public function generateNonce(RequestInterface $request) { return sha1(uniqid('', true) . $request->getUrl()); } /** * Gets timestamp from event or create new timestamp * * @param Event $event Event containing contextual information * * @return int */ public function getTimestamp(Event $event) { return $event['timestamp'] ?: time(); } /** * Convert booleans to strings, removed unset parameters, and sorts the array * * @param array $data Data array * * @return array */ protected function prepareParameters($data) { ksort($data); foreach ($data as $key => &$value) { switch (gettype($value)) { case 'NULL': unset($data[$key]); break; case 'array': $data[$key] = self::prepareParameters($value); break; case 'boolean': $data[$key] = $value ? 'true' : 'false'; break; } } return $data; } } 'JSON_ERROR_NONE - No errors', JSON_ERROR_DEPTH => 'JSON_ERROR_DEPTH - Maximum stack depth exceeded', JSON_ERROR_STATE_MISMATCH => 'JSON_ERROR_STATE_MISMATCH - Underflow or the modes mismatch', JSON_ERROR_CTRL_CHAR => 'JSON_ERROR_CTRL_CHAR - Unexpected control character found', JSON_ERROR_SYNTAX => 'JSON_ERROR_SYNTAX - Syntax error, malformed JSON', JSON_ERROR_UTF8 => 'JSON_ERROR_UTF8 - Malformed UTF-8 characters, possibly incorrectly encoded' ); public function load($config, array $options = array()) { // Reset the array of loaded files because this is a new config $this->loadedFiles = array(); if (is_string($config)) { $config = $this->loadFile($config); } elseif (!is_array($config)) { throw new InvalidArgumentException('Unknown type passed to configuration loader: ' . gettype($config)); } else { $this->mergeIncludes($config); } return $this->build($config, $options); } /** * Add an include alias to the loader * * @param string $filename Filename to alias (e.g. _foo) * @param string $alias Actual file to use (e.g. /path/to/foo.json) * * @return self */ public function addAlias($filename, $alias) { $this->aliases[$filename] = $alias; return $this; } /** * Remove an alias from the loader * * @param string $alias Alias to remove * * @return self */ public function removeAlias($alias) { unset($this->aliases[$alias]); return $this; } /** * Perform the parsing of a config file and create the end result * * @param array $config Configuration data * @param array $options Options to use when building * * @return mixed */ protected abstract function build($config, array $options); /** * Load a configuration file (can load JSON or PHP files that return an array when included) * * @param string $filename File to load * * @return array * @throws InvalidArgumentException * @throws RuntimeException when the JSON cannot be parsed */ protected function loadFile($filename) { if (isset($this->aliases[$filename])) { $filename = $this->aliases[$filename]; } switch (pathinfo($filename, PATHINFO_EXTENSION)) { case 'js': case 'json': $level = error_reporting(0); $json = file_get_contents($filename); error_reporting($level); if ($json === false) { $err = error_get_last(); throw new InvalidArgumentException("Unable to open {$filename}: " . $err['message']); } $config = json_decode($json, true); // Throw an exception if there was an error loading the file if ($error = json_last_error()) { $message = isset(self::$jsonErrors[$error]) ? self::$jsonErrors[$error] : 'Unknown error'; throw new RuntimeException("Error loading JSON data from {$filename}: ({$error}) - {$message}"); } break; case 'php': if (!is_readable($filename)) { throw new InvalidArgumentException("Unable to open {$filename} for reading"); } $config = require $filename; if (!is_array($config)) { throw new InvalidArgumentException('PHP files must return an array of configuration data'); } break; default: throw new InvalidArgumentException('Unknown file extension: ' . $filename); } // Keep track of this file being loaded to prevent infinite recursion $this->loadedFiles[$filename] = true; // Merge include files into the configuration array $this->mergeIncludes($config, dirname($filename)); return $config; } /** * Merges in all include files * * @param array $config Config data that contains includes * @param string $basePath Base path to use when a relative path is encountered * * @return array Returns the merged and included data */ protected function mergeIncludes(&$config, $basePath = null) { if (!empty($config['includes'])) { foreach ($config['includes'] as &$path) { // Account for relative paths if ($path[0] != DIRECTORY_SEPARATOR && !isset($this->aliases[$path]) && $basePath) { $path = "{$basePath}/{$path}"; } // Don't load the same files more than once if (!isset($this->loadedFiles[$path])) { $this->loadedFiles[$path] = true; $config = $this->mergeData($this->loadFile($path), $config); } } } } /** * Default implementation for merging two arrays of data (uses array_merge_recursive) * * @param array $a Original data * @param array $b Data to merge into the original and overwrite existing values * * @return array */ protected function mergeData(array $a, array $b) { return array_merge_recursive($a, $b); } } load($config, $globalParameters); } /** * @param array $serviceBuilderConfig Service configuration settings: * - name: Name of the service * - class: Client class to instantiate using a factory method * - params: array of key value pair configuration settings for the builder */ public function __construct(array $serviceBuilderConfig = array()) { $this->builderConfig = $serviceBuilderConfig; } public static function getAllEvents() { return array('service_builder.create_client'); } public function unserialize($serialized) { $this->builderConfig = json_decode($serialized, true); } public function serialize() { return json_encode($this->builderConfig); } /** * Attach a plugin to every client created by the builder * * @param EventSubscriberInterface $plugin Plugin to attach to each client * * @return self */ public function addGlobalPlugin(EventSubscriberInterface $plugin) { $this->plugins[] = $plugin; return $this; } /** * Get data from the service builder without triggering the building of a service * * @param string $name Name of the service to retrieve * * @return array|null */ public function getData($name) { return isset($this->builderConfig[$name]) ? $this->builderConfig[$name] : null; } public function get($name, $throwAway = false) { if (!isset($this->builderConfig[$name])) { // Check to see if arbitrary data is being referenced if (isset($this->clients[$name])) { return $this->clients[$name]; } // Check aliases and return a match if found foreach ($this->builderConfig as $actualName => $config) { if (isset($config['alias']) && $config['alias'] == $name) { return $this->get($actualName, $throwAway); } } throw new ServiceNotFoundException('No service is registered as ' . $name); } if (!$throwAway && isset($this->clients[$name])) { return $this->clients[$name]; } $builder =& $this->builderConfig[$name]; // Convert references to the actual client foreach ($builder['params'] as &$v) { if (is_string($v) && substr($v, 0, 1) == '{' && substr($v, -1) == '}') { $v = $this->get(trim($v, '{} ')); } } // Get the configured parameters and merge in any parameters provided for throw-away clients $config = $builder['params']; if (is_array($throwAway)) { $config = $throwAway + $config; } $client = $builder['class']::factory($config); if (!$throwAway) { $this->clients[$name] = $client; } if ($client instanceof ClientInterface) { foreach ($this->plugins as $plugin) { $client->addSubscriber($plugin); } // Dispatch an event letting listeners know a client was created $this->dispatch('service_builder.create_client', array('client' => $client)); } return $client; } public function set($key, $service) { if (is_array($service) && isset($service['class']) && isset($service['params'])) { $this->builderConfig[$key] = $service; } else { $this->clients[$key] = $service; } return $this; } public function offsetSet($offset, $value) { $this->set($offset, $value); } public function offsetUnset($offset) { unset($this->builderConfig[$offset]); unset($this->clients[$offset]); } public function offsetExists($offset) { return isset($this->builderConfig[$offset]) || isset($this->clients[$offset]); } public function offsetGet($offset) { return $this->get($offset); } } &$service) { $service['params'] = isset($service['params']) ? $service['params'] : array(); // Check if this client builder extends another client if (!empty($service['extends'])) { // Make sure that the service it's extending has been defined if (!isset($services[$service['extends']])) { throw new ServiceNotFoundException( "{$name} is trying to extend a non-existent service: {$service['extends']}" ); } $extended = &$services[$service['extends']]; // Use the correct class attribute if (empty($service['class'])) { $service['class'] = isset($extended['class']) ? $extended['class'] : ''; } if ($extendsParams = isset($extended['params']) ? $extended['params'] : false) { $service['params'] = $service['params'] + $extendsParams; } } // Overwrite default values with global parameter values if (!empty($options)) { $service['params'] = $options + $service['params']; } $service['class'] = isset($service['class']) ? $service['class'] : ''; } return new $class($services); } protected function mergeData(array $a, array $b) { $result = $b + $a; // Merge services using a recursive union of arrays if (isset($a['services']) && $b['services']) { // Get a union of the services of the two arrays $result['services'] = $b['services'] + $a['services']; // Merge each service in using a union of the two arrays foreach ($result['services'] as $name => &$service) { // By default, services completely override a previously defined service unless it extends itself if (isset($a['services'][$name]['extends']) && isset($b['services'][$name]['extends']) && $b['services'][$name]['extends'] == $name ) { $service += $a['services'][$name]; // Use the `extends` attribute of the parent $service['extends'] = $a['services'][$name]['extends']; // Merge parameters using a union if both have parameters if (isset($a['services'][$name]['params'])) { $service['params'] += $a['services'][$name]['params']; } } } } return $result; } } loader = $loader; $this->cache = $cache; } public function load($config, array $options = array()) { if (!is_string($config)) { $key = false; } else { $key = 'loader_' . crc32($config); if ($result = $this->cache->fetch($key)) { return $result; } } $result = $this->loader->load($config, $options); if ($key) { $this->cache->save($key, $result); } return $result; } } getCommand($method, isset($args[0]) ? $args[0] : array())->getResult(); } public function getCommand($name, array $args = array()) { // Add global client options to the command if ($options = $this->getConfig(self::COMMAND_PARAMS)) { $args += $options; } if (!($command = $this->getCommandFactory()->factory($name, $args))) { throw new InvalidArgumentException("Command was not found matching {$name}"); } $command->setClient($this); $this->dispatch('client.command.create', array('client' => $this, 'command' => $command)); return $command; } /** * Set the command factory used to create commands by name * * @param CommandFactoryInterface $factory Command factory * * @return self */ public function setCommandFactory(CommandFactoryInterface $factory) { $this->commandFactory = $factory; return $this; } /** * Set the resource iterator factory associated with the client * * @param ResourceIteratorFactoryInterface $factory Resource iterator factory * * @return self */ public function setResourceIteratorFactory(ResourceIteratorFactoryInterface $factory) { $this->resourceIteratorFactory = $factory; return $this; } public function getIterator($command, array $commandOptions = null, array $iteratorOptions = array()) { if (!($command instanceof CommandInterface)) { $command = $this->getCommand($command, $commandOptions ?: array()); } return $this->getResourceIteratorFactory()->build($command, $iteratorOptions); } public function execute($command) { if ($command instanceof CommandInterface) { $this->send($this->prepareCommand($command)); $this->dispatch('command.after_send', array('command' => $command)); return $command->getResult(); } elseif (is_array($command) || $command instanceof \Traversable) { return $this->executeMultiple($command); } else { throw new InvalidArgumentException('Command must be a command or array of commands'); } } public function setDescription(ServiceDescriptionInterface $service) { $this->serviceDescription = $service; // If a baseUrl was set on the description, then update the client if ($baseUrl = $service->getBaseUrl()) { $this->setBaseUrl($baseUrl); } return $this; } public function getDescription() { return $this->serviceDescription; } /** * Set the inflector used with the client * * @param InflectorInterface $inflector Inflection object * * @return self */ public function setInflector(InflectorInterface $inflector) { $this->inflector = $inflector; return $this; } /** * Get the inflector used with the client * * @return self */ public function getInflector() { if (!$this->inflector) { $this->inflector = Inflector::getDefault(); } return $this->inflector; } /** * Prepare a command for sending and get the RequestInterface object created by the command * * @param CommandInterface $command Command to prepare * * @return RequestInterface */ protected function prepareCommand(CommandInterface $command) { // Set the client and prepare the command $request = $command->setClient($this)->prepare(); // Set the state to new if the command was previously executed $request->setState(RequestInterface::STATE_NEW); $this->dispatch('command.before_send', array('command' => $command)); return $request; } /** * Execute multiple commands in parallel * * @param array|Traversable $commands Array of CommandInterface objects to execute * * @return array Returns an array of the executed commands * @throws Exception\CommandTransferException */ protected function executeMultiple($commands) { $requests = array(); $commandRequests = new \SplObjectStorage(); foreach ($commands as $command) { $request = $this->prepareCommand($command); $commandRequests[$request] = $command; $requests[] = $request; } try { $this->send($requests); foreach ($commands as $command) { $this->dispatch('command.after_send', array('command' => $command)); } return $commands; } catch (MultiTransferException $failureException) { // Throw a CommandTransferException using the successful and failed commands $e = CommandTransferException::fromMultiTransferException($failureException); // Remove failed requests from the successful requests array and add to the failures array foreach ($failureException->getFailedRequests() as $request) { if (isset($commandRequests[$request])) { $e->addFailedCommand($commandRequests[$request]); unset($commandRequests[$request]); } } // Always emit the command after_send events for successful commands foreach ($commandRequests as $success) { $e->addSuccessfulCommand($commandRequests[$success]); $this->dispatch('command.after_send', array('command' => $commandRequests[$success])); } throw $e; } } protected function getResourceIteratorFactory() { if (!$this->resourceIteratorFactory) { // Build the default resource iterator factory if one is not set $clientClass = get_class($this); $prefix = substr($clientClass, 0, strrpos($clientClass, '\\')); $this->resourceIteratorFactory = new ResourceIteratorClassFactory(array( "{$prefix}\\Iterator", "{$prefix}\\Model" )); } return $this->resourceIteratorFactory; } /** * Get the command factory associated with the client * * @return CommandFactoryInterface */ protected function getCommandFactory() { if (!$this->commandFactory) { $this->commandFactory = CompositeFactory::getDefaultChain($this); } return $this->commandFactory; } /** * @deprecated * @codeCoverageIgnore */ public function enableMagicMethods($isEnabled) { Version::warn(__METHOD__ . ' is deprecated'); } } operation = $operation ?: $this->createOperation(); foreach ($this->operation->getParams() as $name => $arg) { $currentValue = $this[$name]; $configValue = $arg->getValue($currentValue); // If default or static values are set, then this should always be updated on the config object if ($currentValue !== $configValue) { $this[$name] = $configValue; } } $headers = $this[self::HEADERS_OPTION]; if (!$headers instanceof Collection) { $this[self::HEADERS_OPTION] = new Collection((array) $headers); } // You can set a command.on_complete option in your parameters to set an onComplete callback if ($onComplete = $this['command.on_complete']) { unset($this['command.on_complete']); $this->setOnComplete($onComplete); } // Set the hidden additional parameters if (!$this[self::HIDDEN_PARAMS]) { $this[self::HIDDEN_PARAMS] = array( self::HEADERS_OPTION, self::RESPONSE_PROCESSING, self::HIDDEN_PARAMS, self::REQUEST_OPTIONS ); } $this->init(); } /** * Custom clone behavior */ public function __clone() { $this->request = null; $this->result = null; } /** * Execute the command in the same manner as calling a function * * @return mixed Returns the result of {@see AbstractCommand::execute} */ public function __invoke() { return $this->execute(); } public function getName() { return $this->operation->getName(); } /** * Get the API command information about the command * * @return OperationInterface */ public function getOperation() { return $this->operation; } public function setOnComplete($callable) { if (!is_callable($callable)) { throw new InvalidArgumentException('The onComplete function must be callable'); } $this->onComplete = $callable; return $this; } public function execute() { if (!$this->client) { throw new CommandException('A client must be associated with the command before it can be executed.'); } return $this->client->execute($this); } public function getClient() { return $this->client; } public function setClient(ClientInterface $client) { $this->client = $client; return $this; } public function getRequest() { if (!$this->request) { throw new CommandException('The command must be prepared before retrieving the request'); } return $this->request; } public function getResponse() { if (!$this->isExecuted()) { $this->execute(); } return $this->request->getResponse(); } public function getResult() { if (!$this->isExecuted()) { $this->execute(); } if (null === $this->result) { $this->process(); // Call the onComplete method if one is set if ($this->onComplete) { call_user_func($this->onComplete, $this); } } return $this->result; } public function setResult($result) { $this->result = $result; return $this; } public function isPrepared() { return $this->request !== null; } public function isExecuted() { return $this->request !== null && $this->request->getState() == 'complete'; } public function prepare() { if (!$this->isPrepared()) { if (!$this->client) { throw new CommandException('A client must be associated with the command before it can be prepared.'); } // If no response processing value was specified, then attempt to use the highest level of processing if (!isset($this[self::RESPONSE_PROCESSING])) { $this[self::RESPONSE_PROCESSING] = self::TYPE_MODEL; } // Notify subscribers of the client that the command is being prepared $this->client->dispatch('command.before_prepare', array('command' => $this)); // Fail on missing required arguments, and change parameters via filters $this->validate(); // Delegate to the subclass that implements the build method $this->build(); // Add custom request headers set on the command if ($headers = $this[self::HEADERS_OPTION]) { foreach ($headers as $key => $value) { $this->request->setHeader($key, $value); } } // Add any curl options to the request if ($options = $this[Client::CURL_OPTIONS]) { $this->request->getCurlOptions()->overwriteWith(CurlHandle::parseCurlConfig($options)); } // Set a custom response body if ($responseBody = $this[self::RESPONSE_BODY]) { $this->request->setResponseBody($responseBody); } $this->client->dispatch('command.after_prepare', array('command' => $this)); } return $this->request; } /** * Set the validator used to validate and prepare command parameters and nested JSON schemas. If no validator is * set, then the command will validate using the default {@see SchemaValidator}. * * @param ValidatorInterface $validator Validator used to prepare and validate properties against a JSON schema * * @return self */ public function setValidator(ValidatorInterface $validator) { $this->validator = $validator; return $this; } public function getRequestHeaders() { return $this[self::HEADERS_OPTION]; } /** * Initialize the command (hook that can be implemented in subclasses) */ protected function init() {} /** * Create the request object that will carry out the command */ abstract protected function build(); /** * Hook used to create an operation for concrete commands that are not associated with a service description * * @return OperationInterface */ protected function createOperation() { return new Operation(array('name' => get_class($this))); } /** * Create the result of the command after the request has been completed. * Override this method in subclasses to customize this behavior */ protected function process() { $this->result = $this[self::RESPONSE_PROCESSING] != self::TYPE_RAW ? DefaultResponseParser::getInstance()->parse($this) : $this->request->getResponse(); } /** * Validate and prepare the command based on the schema and rules defined by the command's Operation object * * @throws ValidationException when validation errors occur */ protected function validate() { // Do not perform request validation/transformation if it is disable if ($this[self::DISABLE_VALIDATION]) { return; } $errors = array(); $validator = $this->getValidator(); foreach ($this->operation->getParams() as $name => $schema) { $value = $this[$name]; if (!$validator->validate($schema, $value)) { $errors = array_merge($errors, $validator->getErrors()); } elseif ($value !== $this[$name]) { // Update the config value if it changed and no validation errors were encountered $this->data[$name] = $value; } } // Validate additional parameters $hidden = $this[self::HIDDEN_PARAMS]; if ($properties = $this->operation->getAdditionalParameters()) { foreach ($this->toArray() as $name => $value) { // It's only additional if it isn't defined in the schema if (!$this->operation->hasParam($name) && !in_array($name, $hidden)) { // Always set the name so that error messages are useful $properties->setName($name); if (!$validator->validate($properties, $value)) { $errors = array_merge($errors, $validator->getErrors()); } elseif ($value !== $this[$name]) { $this->data[$name] = $value; } } } } if (!empty($errors)) { $e = new ValidationException('Validation errors: ' . implode("\n", $errors)); $e->setErrors($errors); throw $e; } } /** * Get the validator used to prepare and validate properties. If no validator has been set on the command, then * the default {@see SchemaValidator} will be used. * * @return ValidatorInterface */ protected function getValidator() { if (!$this->validator) { $this->validator = SchemaValidator::getInstance(); } return $this->validator; } /** * Get array of any validation errors * If no validator has been set then return false */ public function getValidationErrors() { if (!$this->validator) { return false; } return $this->validator->getErrors(); } } request = $closure($this, $this->operation); if (!$this->request || !$this->request instanceof RequestInterface) { throw new UnexpectedValueException('Closure command did not return a RequestInterface object'); } } } stopPropagation(); } /** * Get the created object * * @return mixed */ public function getResult() { return $this['result']; } } factory = $factory; } /** * Add a location visitor to the serializer * * @param string $location Location to associate with the visitor * @param RequestVisitorInterface $visitor Visitor to attach * * @return self */ public function addVisitor($location, RequestVisitorInterface $visitor) { $this->factory->addRequestVisitor($location, $visitor); return $this; } public function prepare(CommandInterface $command) { $request = $this->createRequest($command); // Keep an array of visitors found in the operation $foundVisitors = array(); $operation = $command->getOperation(); // Add arguments to the request using the location attribute foreach ($operation->getParams() as $name => $arg) { /** @var $arg \Guzzle\Service\Description\Parameter */ $location = $arg->getLocation(); // Skip 'uri' locations because they've already been processed if ($location && $location != 'uri') { // Instantiate visitors as they are detected in the properties if (!isset($foundVisitors[$location])) { $foundVisitors[$location] = $this->factory->getRequestVisitor($location); } // Ensure that a value has been set for this parameter $value = $command[$name]; if ($value !== null) { // Apply the parameter value with the location visitor $foundVisitors[$location]->visit($command, $request, $arg, $value); } } } // Serialize additional parameters if ($additional = $operation->getAdditionalParameters()) { if ($visitor = $this->prepareAdditionalParameters($operation, $command, $request, $additional)) { $foundVisitors[$additional->getLocation()] = $visitor; } } // Call the after method on each visitor found in the operation foreach ($foundVisitors as $visitor) { $visitor->after($command, $request); } return $request; } /** * Serialize additional parameters * * @param OperationInterface $operation Operation that owns the command * @param CommandInterface $command Command to prepare * @param RequestInterface $request Request to serialize * @param Parameter $additional Additional parameters * * @return null|RequestVisitorInterface */ protected function prepareAdditionalParameters( OperationInterface $operation, CommandInterface $command, RequestInterface $request, Parameter $additional ) { if (!($location = $additional->getLocation())) { return; } $visitor = $this->factory->getRequestVisitor($location); $hidden = $command[$command::HIDDEN_PARAMS]; foreach ($command->toArray() as $key => $value) { // Ignore values that are null or built-in command options if ($value !== null && !in_array($key, $hidden) && !$operation->hasParam($key) ) { $additional->setName($key); $visitor->visit($command, $request, $additional, $value); } } return $visitor; } /** * Create a request for the command and operation * * @param CommandInterface $command Command to create a request for * * @return RequestInterface */ protected function createRequest(CommandInterface $command) { $operation = $command->getOperation(); $client = $command->getClient(); $options = $command[AbstractCommand::REQUEST_OPTIONS] ?: array(); // If the command does not specify a template, then assume the base URL of the client if (!($uri = $operation->getUri())) { return $client->createRequest($operation->getHttpMethod(), $client->getBaseUrl(), null, null, $options); } // Get the path values and use the client config settings $variables = array(); foreach ($operation->getParams() as $name => $arg) { if ($arg->getLocation() == 'uri') { if (isset($command[$name])) { $variables[$name] = $arg->filter($command[$name]); if (!is_array($variables[$name])) { $variables[$name] = (string) $variables[$name]; } } } } return $client->createRequest($operation->getHttpMethod(), array($uri, $variables), null, null, $options); } } getRequest()->getResponse(); // Account for hard coded content-type values specified in service descriptions if ($contentType = $command['command.expects']) { $response->setHeader('Content-Type', $contentType); } else { $contentType = (string) $response->getHeader('Content-Type'); } return $this->handleParsing($command, $response, $contentType); } protected function handleParsing(CommandInterface $command, Response $response, $contentType) { $result = $response; if ($result->getBody()) { if (stripos($contentType, 'json') !== false) { $result = $result->json(); } elseif (stripos($contentType, 'xml') !== false) { $result = $result->xml(); } } return $result; } } client = $client; $this->aliases = $aliases; } public function factory($name, array $args = array()) { if (isset($this->aliases[$name])) { try { return $this->client->getCommand($this->aliases[$name], $args); } catch (InvalidArgumentException $e) { return null; } } } } getDescription()) { $factories[] = new ServiceDescriptionFactory($description); } $factories[] = new ConcreteClassFactory($client); return new self($factories); } /** * @param array $factories Array of command factories */ public function __construct(array $factories = array()) { $this->factories = $factories; } /** * Add a command factory to the chain * * @param FactoryInterface $factory Factory to add * @param string|FactoryInterface $before Insert the new command factory before a command factory class or object * matching a class name. * @return CompositeFactory */ public function add(FactoryInterface $factory, $before = null) { $pos = null; if ($before) { foreach ($this->factories as $i => $f) { if ($before instanceof FactoryInterface) { if ($f === $before) { $pos = $i; break; } } elseif (is_string($before)) { if ($f instanceof $before) { $pos = $i; break; } } } } if ($pos === null) { $this->factories[] = $factory; } else { array_splice($this->factories, $i, 0, array($factory)); } return $this; } /** * Check if the chain contains a specific command factory * * @param FactoryInterface|string $factory Factory to check * * @return bool */ public function has($factory) { return (bool) $this->find($factory); } /** * Remove a specific command factory from the chain * * @param string|FactoryInterface $factory Factory to remove by name or instance * * @return CompositeFactory */ public function remove($factory = null) { if (!($factory instanceof FactoryInterface)) { $factory = $this->find($factory); } $this->factories = array_values(array_filter($this->factories, function($f) use ($factory) { return $f !== $factory; })); return $this; } /** * Get a command factory by class name * * @param string|FactoryInterface $factory Command factory class or instance * * @return null|FactoryInterface */ public function find($factory) { foreach ($this->factories as $f) { if ($factory === $f || (is_string($factory) && $f instanceof $factory)) { return $f; } } } /** * Create a command using the associated command factories * * @param string $name Name of the command * @param array $args Command arguments * * @return CommandInterface */ public function factory($name, array $args = array()) { foreach ($this->factories as $factory) { $command = $factory->factory($name, $args); if ($command) { return $command; } } } public function count() { return count($this->factories); } public function getIterator() { return new \ArrayIterator($this->factories); } } client = $client; $this->inflector = $inflector ?: Inflector::getDefault(); } public function factory($name, array $args = array()) { // Determine the class to instantiate based on the namespace of the current client and the default directory $prefix = $this->client->getConfig('command.prefix'); if (!$prefix) { // The prefix can be specified in a factory method and is cached $prefix = implode('\\', array_slice(explode('\\', get_class($this->client)), 0, -1)) . '\\Command\\'; $this->client->getConfig()->set('command.prefix', $prefix); } $class = $prefix . str_replace(' ', '\\', ucwords(str_replace('.', ' ', $this->inflector->camel($name)))); // Create the concrete command if it exists if (class_exists($class)) { return new $class($args); } } } map = $map; } public function factory($name, array $args = array()) { if (isset($this->map[$name])) { $class = $this->map[$name]; return new $class($args); } } } setServiceDescription($description); $this->inflector = $inflector; } /** * Change the service description used with the factory * * @param ServiceDescriptionInterface $description Service description to use * * @return FactoryInterface */ public function setServiceDescription(ServiceDescriptionInterface $description) { $this->description = $description; return $this; } /** * Returns the service description * * @return ServiceDescriptionInterface */ public function getServiceDescription() { return $this->description; } public function factory($name, array $args = array()) { $command = $this->description->getOperation($name); // If a command wasn't found, then try to uppercase the first letter and try again if (!$command) { $command = $this->description->getOperation(ucfirst($name)); // If an inflector was passed, then attempt to get the command using snake_case inflection if (!$command && $this->inflector) { $command = $this->description->getOperation($this->inflector->snake($name)); } } if ($command) { $class = $command->getClass(); return new $class($args, $command, $this->description); } } } resolveRecursively($value, $param) : $param->filter($value); } /** * Map nested parameters into the location_key based parameters * * @param array $value Value to map * @param Parameter $param Parameter that holds information about the current key * * @return array Returns the mapped array */ protected function resolveRecursively(array $value, Parameter $param) { foreach ($value as $name => &$v) { switch ($param->getType()) { case 'object': if ($subParam = $param->getProperty($name)) { $key = $subParam->getWireName(); $value[$key] = $this->prepareValue($v, $subParam); if ($name != $key) { unset($value[$name]); } } elseif ($param->getAdditionalProperties() instanceof Parameter) { $v = $this->prepareValue($v, $param->getAdditionalProperties()); } break; case 'array': if ($items = $param->getItems()) { $v = $this->prepareValue($v, $items); } break; } } return $param->filter($value); } } filter($value); $entityBody = EntityBody::factory($value); $request->setBody($entityBody); $this->addExpectHeader($request, $entityBody, $param->getData('expect_header')); // Add the Content-Encoding header if one is set on the EntityBody if ($encoding = $entityBody->getContentEncoding()) { $request->setHeader('Content-Encoding', $encoding); } } /** * Add the appropriate expect header to a request * * @param EntityEnclosingRequestInterface $request Request to update * @param EntityBodyInterface $body Entity body of the request * @param string|int $expect Expect header setting */ protected function addExpectHeader(EntityEnclosingRequestInterface $request, EntityBodyInterface $body, $expect) { // Allow the `expect` data parameter to be set to remove the Expect header from the request if ($expect === false) { $request->removeHeader('Expect'); } elseif ($expect !== true) { // Default to using a MB as the point in which to start using the expect header $expect = $expect ?: 1048576; // If the expect_header value is numeric then only add if the size is greater than the cutoff if (is_numeric($expect) && $body->getSize()) { if ($body->getSize() < $expect) { $request->removeHeader('Expect'); } else { $request->setHeader('Expect', '100-Continue'); } } } } } filter($value); if ($param->getType() == 'object' && $param->getAdditionalProperties() instanceof Parameter) { $this->addPrefixedHeaders($request, $param, $value); } else { $request->setHeader($param->getWireName(), $value); } } /** * Add a prefixed array of headers to the request * * @param RequestInterface $request Request to update * @param Parameter $param Parameter object * @param array $value Header array to add * * @throws InvalidArgumentException */ protected function addPrefixedHeaders(RequestInterface $request, Parameter $param, $value) { if (!is_array($value)) { throw new InvalidArgumentException('An array of mapped headers expected, but received a single value'); } $prefix = $param->getSentAs(); foreach ($value as $headerName => $headerValue) { $request->setHeader($prefix . $headerName, $headerValue); } } } data = new \SplObjectStorage(); } /** * Set the Content-Type header to add to the request if JSON is added to the body. This visitor does not add a * Content-Type header unless you specify one here. * * @param string $header Header to set when JSON is added (e.g. application/json) * * @return self */ public function setContentTypeHeader($header = 'application/json') { $this->jsonContentType = $header; return $this; } public function visit(CommandInterface $command, RequestInterface $request, Parameter $param, $value) { if (isset($this->data[$command])) { $json = $this->data[$command]; } else { $json = array(); } $json[$param->getWireName()] = $this->prepareValue($value, $param); $this->data[$command] = $json; } public function after(CommandInterface $command, RequestInterface $request) { if (isset($this->data[$command])) { // Don't overwrite the Content-Type if one is set if ($this->jsonContentType && !$request->hasHeader('Content-Type')) { $request->setHeader('Content-Type', $this->jsonContentType); } $request->setBody(json_encode($this->data[$command])); unset($this->data[$command]); } } } setPostField($param->getWireName(), $this->prepareValue($value, $param)); } } filter($value); if ($value instanceof PostFileInterface) { $request->addPostFile($value); } else { $request->addPostFile($param->getWireName(), $value); } } } getQuery()->set($param->getWireName(), $this->prepareValue($value, $param)); } } setResponseBody($value); } } data = new \SplObjectStorage(); } /** * Change the content-type header that is added when XML is found * * @param string $header Header to set when XML is found * * @return self */ public function setContentTypeHeader($header) { $this->contentType = $header; return $this; } public function visit(CommandInterface $command, RequestInterface $request, Parameter $param, $value) { $xml = isset($this->data[$command]) ? $this->data[$command] : $this->createRootElement($param->getParent()); $this->addXml($xml, $param, $value); $this->data[$command] = $xml; } public function after(CommandInterface $command, RequestInterface $request) { $xml = null; // If data was found that needs to be serialized, then do so if (isset($this->data[$command])) { $xml = $this->finishDocument($this->data[$command]); unset($this->data[$command]); } else { // Check if XML should always be sent for the command $operation = $command->getOperation(); if ($operation->getData('xmlAllowEmpty')) { $xmlWriter = $this->createRootElement($operation); $xml = $this->finishDocument($xmlWriter); } } if ($xml) { // Don't overwrite the Content-Type if one is set if ($this->contentType && !$request->hasHeader('Content-Type')) { $request->setHeader('Content-Type', $this->contentType); } $request->setBody($xml); } } /** * Create the root XML element to use with a request * * @param Operation $operation Operation object * * @return \XMLWriter */ protected function createRootElement(Operation $operation) { static $defaultRoot = array('name' => 'Request'); // If no root element was specified, then just wrap the XML in 'Request' $root = $operation->getData('xmlRoot') ?: $defaultRoot; // Allow the XML declaration to be customized with xmlEncoding $encoding = $operation->getData('xmlEncoding'); $xmlWriter = $this->startDocument($encoding); $xmlWriter->startElement($root['name']); // Create the wrapping element with no namespaces if no namespaces were present if (!empty($root['namespaces'])) { // Create the wrapping element with an array of one or more namespaces foreach ((array) $root['namespaces'] as $prefix => $uri) { $nsLabel = 'xmlns'; if (!is_numeric($prefix)) { $nsLabel .= ':'.$prefix; } $xmlWriter->writeAttribute($nsLabel, $uri); } } return $xmlWriter; } /** * Recursively build the XML body * * @param \XMLWriter $xmlWriter XML to modify * @param Parameter $param API Parameter * @param mixed $value Value to add */ protected function addXml(\XMLWriter $xmlWriter, Parameter $param, $value) { if ($value === null) { return; } $value = $param->filter($value); $type = $param->getType(); $name = $param->getWireName(); $prefix = null; $namespace = $param->getData('xmlNamespace'); if (false !== strpos($name, ':')) { list($prefix, $name) = explode(':', $name, 2); } if ($type == 'object' || $type == 'array') { if (!$param->getData('xmlFlattened')) { $xmlWriter->startElementNS(null, $name, $namespace); } if ($param->getType() == 'array') { $this->addXmlArray($xmlWriter, $param, $value); } elseif ($param->getType() == 'object') { $this->addXmlObject($xmlWriter, $param, $value); } if (!$param->getData('xmlFlattened')) { $xmlWriter->endElement(); } return; } if ($param->getData('xmlAttribute')) { $this->writeAttribute($xmlWriter, $prefix, $name, $namespace, $value); } else { $this->writeElement($xmlWriter, $prefix, $name, $namespace, $value); } } /** * Write an attribute with namespace if used * * @param \XMLWriter $xmlWriter XMLWriter instance * @param string $prefix Namespace prefix if any * @param string $name Attribute name * @param string $namespace The uri of the namespace * @param string $value The attribute content */ protected function writeAttribute($xmlWriter, $prefix, $name, $namespace, $value) { if (empty($namespace)) { $xmlWriter->writeAttribute($name, $value); } else { $xmlWriter->writeAttributeNS($prefix, $name, $namespace, $value); } } /** * Write an element with namespace if used * * @param \XMLWriter $xmlWriter XML writer resource * @param string $prefix Namespace prefix if any * @param string $name Element name * @param string $namespace The uri of the namespace * @param string $value The element content */ protected function writeElement(\XMLWriter $xmlWriter, $prefix, $name, $namespace, $value) { $xmlWriter->startElementNS($prefix, $name, $namespace); if (strpbrk($value, '<>&')) { $xmlWriter->writeCData($value); } else { $xmlWriter->writeRaw($value); } $xmlWriter->endElement(); } /** * Create a new xml writer and start a document * * @param string $encoding document encoding * * @return \XMLWriter the writer resource */ protected function startDocument($encoding) { $xmlWriter = new \XMLWriter(); $xmlWriter->openMemory(); $xmlWriter->startDocument('1.0', $encoding); return $xmlWriter; } /** * End the document and return the output * * @param \XMLWriter $xmlWriter * * @return \string the writer resource */ protected function finishDocument($xmlWriter) { $xmlWriter->endDocument(); return $xmlWriter->outputMemory(); } /** * Add an array to the XML */ protected function addXmlArray(\XMLWriter $xmlWriter, Parameter $param, &$value) { if ($items = $param->getItems()) { foreach ($value as $v) { $this->addXml($xmlWriter, $items, $v); } } } /** * Add an object to the XML */ protected function addXmlObject(\XMLWriter $xmlWriter, Parameter $param, &$value) { $noAttributes = array(); // add values which have attributes foreach ($value as $name => $v) { if ($property = $param->getProperty($name)) { if ($property->getData('xmlAttribute')) { $this->addXml($xmlWriter, $property, $v); } else { $noAttributes[] = array('value' => $v, 'property' => $property); } } } // now add values with no attributes foreach ($noAttributes as $element) { $this->addXml($xmlWriter, $element['property'], $element['value']); } } } getName()] = $param->filter($response->getBody()); } } getType() == 'object' && $param->getAdditionalProperties() instanceof Parameter) { $this->processPrefixedHeaders($response, $param, $value); } else { $value[$param->getName()] = $param->filter((string) $response->getHeader($param->getWireName())); } } /** * Process a prefixed header array * * @param Response $response Response that contains the headers * @param Parameter $param Parameter object * @param array $value Value response array to modify */ protected function processPrefixedHeaders(Response $response, Parameter $param, &$value) { // Grab prefixed headers that should be placed into an array with the prefix stripped if ($prefix = $param->getSentAs()) { $container = $param->getName(); $len = strlen($prefix); // Find all matching headers and place them into the containing element foreach ($response->getHeaders()->toArray() as $key => $header) { if (stripos($key, $prefix) === 0) { // Account for multi-value headers $value[$container][substr($key, $len)] = count($header) == 1 ? end($header) : $header; } } } } } getResponse()->json(); } public function visit( CommandInterface $command, Response $response, Parameter $param, &$value, $context = null ) { $name = $param->getName(); $key = $param->getWireName(); if (isset($value[$key])) { $this->recursiveProcess($param, $value[$key]); if ($key != $name) { $value[$name] = $value[$key]; unset($value[$key]); } } } /** * Recursively process a parameter while applying filters * * @param Parameter $param API parameter being validated * @param mixed $value Value to validate and process. The value may change during this process. */ protected function recursiveProcess(Parameter $param, &$value) { if ($value === null) { return; } if (is_array($value)) { $type = $param->getType(); if ($type == 'array') { foreach ($value as &$item) { $this->recursiveProcess($param->getItems(), $item); } } elseif ($type == 'object' && !isset($value[0])) { // On the above line, we ensure that the array is associative and not numerically indexed $knownProperties = array(); if ($properties = $param->getProperties()) { foreach ($properties as $property) { $name = $property->getName(); $key = $property->getWireName(); $knownProperties[$name] = 1; if (isset($value[$key])) { $this->recursiveProcess($property, $value[$key]); if ($key != $name) { $value[$name] = $value[$key]; unset($value[$key]); } } } } // Remove any unknown and potentially unsafe properties if ($param->getAdditionalProperties() === false) { $value = array_intersect_key($value, $knownProperties); } elseif (($additional = $param->getAdditionalProperties()) !== true) { // Validate and filter additional properties foreach ($value as &$v) { $this->recursiveProcess($additional, $v); } } } } $value = $param->filter($value); } } getName()] = $response->getReasonPhrase(); } } getName()] = $response->getStatusCode(); } } getResponse()->xml()), true); } public function visit( CommandInterface $command, Response $response, Parameter $param, &$value, $context = null ) { $sentAs = $param->getWireName(); $name = $param->getName(); if (isset($value[$sentAs])) { $this->recursiveProcess($param, $value[$sentAs]); if ($name != $sentAs) { $value[$name] = $value[$sentAs]; unset($value[$sentAs]); } } } /** * Recursively process a parameter while applying filters * * @param Parameter $param API parameter being processed * @param mixed $value Value to validate and process. The value may change during this process. */ protected function recursiveProcess(Parameter $param, &$value) { $type = $param->getType(); if (!is_array($value)) { if ($type == 'array') { // Cast to an array if the value was a string, but should be an array $this->recursiveProcess($param->getItems(), $value); $value = array($value); } } elseif ($type == 'object') { $this->processObject($param, $value); } elseif ($type == 'array') { $this->processArray($param, $value); } if ($value !== null) { $value = $param->filter($value); } } /** * Process an array * * @param Parameter $param API parameter being parsed * @param mixed $value Value to process */ protected function processArray(Parameter $param, &$value) { // Convert the node if it was meant to be an array if (!isset($value[0])) { // Collections fo nodes are sometimes wrapped in an additional array. For example: // 12 should become: // array('Items' => array(array('a' => 1), array('a' => 2)) // Some nodes are not wrapped. For example: 12 // should become array('Foo' => array(array('a' => 1), array('a' => 2)) if ($param->getItems() && isset($value[$param->getItems()->getWireName()])) { // Account for the case of a collection wrapping wrapped nodes: Items => Item[] $value = $value[$param->getItems()->getWireName()]; // If the wrapped node only had one value, then make it an array of nodes if (!isset($value[0]) || !is_array($value)) { $value = array($value); } } elseif (!empty($value)) { // Account for repeated nodes that must be an array: Foo => Baz, Foo => Baz, but only if the // value is set and not empty $value = array($value); } } foreach ($value as &$item) { $this->recursiveProcess($param->getItems(), $item); } } /** * Process an object * * @param Parameter $param API parameter being parsed * @param mixed $value Value to process */ protected function processObject(Parameter $param, &$value) { // Ensure that the array is associative and not numerically indexed if (!isset($value[0]) && ($properties = $param->getProperties())) { $knownProperties = array(); foreach ($properties as $property) { $name = $property->getName(); $sentAs = $property->getWireName(); $knownProperties[$name] = 1; if ($property->getData('xmlAttribute')) { $this->processXmlAttribute($property, $value); } elseif (isset($value[$sentAs])) { $this->recursiveProcess($property, $value[$sentAs]); if ($name != $sentAs) { $value[$name] = $value[$sentAs]; unset($value[$sentAs]); } } } // Remove any unknown and potentially unsafe properties if ($param->getAdditionalProperties() === false) { $value = array_intersect_key($value, $knownProperties); } } } /** * Process an XML attribute property * * @param Parameter $property Property to process * @param array $value Value to process and update */ protected function processXmlAttribute(Parameter $property, array &$value) { $sentAs = $property->getWireName(); if (isset($value['@attributes'][$sentAs])) { $value[$property->getName()] = $value['@attributes'][$sentAs]; unset($value['@attributes'][$sentAs]); if (empty($value['@attributes'])) { unset($value['@attributes']); } } } } 'Guzzle\Service\Command\LocationVisitor\Request\BodyVisitor', 'request.header' => 'Guzzle\Service\Command\LocationVisitor\Request\HeaderVisitor', 'request.json' => 'Guzzle\Service\Command\LocationVisitor\Request\JsonVisitor', 'request.postField' => 'Guzzle\Service\Command\LocationVisitor\Request\PostFieldVisitor', 'request.postFile' => 'Guzzle\Service\Command\LocationVisitor\Request\PostFileVisitor', 'request.query' => 'Guzzle\Service\Command\LocationVisitor\Request\QueryVisitor', 'request.response_body' => 'Guzzle\Service\Command\LocationVisitor\Request\ResponseBodyVisitor', 'request.responseBody' => 'Guzzle\Service\Command\LocationVisitor\Request\ResponseBodyVisitor', 'request.xml' => 'Guzzle\Service\Command\LocationVisitor\Request\XmlVisitor', 'response.body' => 'Guzzle\Service\Command\LocationVisitor\Response\BodyVisitor', 'response.header' => 'Guzzle\Service\Command\LocationVisitor\Response\HeaderVisitor', 'response.json' => 'Guzzle\Service\Command\LocationVisitor\Response\JsonVisitor', 'response.reasonPhrase' => 'Guzzle\Service\Command\LocationVisitor\Response\ReasonPhraseVisitor', 'response.statusCode' => 'Guzzle\Service\Command\LocationVisitor\Response\StatusCodeVisitor', 'response.xml' => 'Guzzle\Service\Command\LocationVisitor\Response\XmlVisitor' ); /** @var array Array of mappings of location names to classes */ protected $mappings; /** @var array Cache of instantiated visitors */ protected $cache = array(); /** * @return self * @codeCoverageIgnore */ public static function getInstance() { if (!self::$instance) { self::$instance = new self(); } return self::$instance; } /** * @param array $mappings Array mapping request.name and response.name to location visitor classes. Leave null to * use the default values. */ public function __construct(array $mappings = null) { $this->mappings = $mappings === null ? self::$defaultMappings : $mappings; } /** * Get an instance of a request visitor by location name * * @param string $visitor Visitor name * * @return RequestVisitorInterface */ public function getRequestVisitor($visitor) { return $this->getKey('request.' . $visitor); } /** * Get an instance of a response visitor by location name * * @param string $visitor Visitor name * * @return ResponseVisitorInterface */ public function getResponseVisitor($visitor) { return $this->getKey('response.' . $visitor); } /** * Add a response visitor to the factory by name * * @param string $name Name of the visitor * @param RequestVisitorInterface $visitor Visitor to add * * @return self */ public function addRequestVisitor($name, RequestVisitorInterface $visitor) { $this->cache['request.' . $name] = $visitor; return $this; } /** * Add a response visitor to the factory by name * * @param string $name Name of the visitor * @param ResponseVisitorInterface $visitor Visitor to add * * @return self */ public function addResponseVisitor($name, ResponseVisitorInterface $visitor) { $this->cache['response.' . $name] = $visitor; return $this; } /** * Get a visitor by key value name * * @param string $key Key name to retrieve * * @return mixed * @throws InvalidArgumentException */ private function getKey($key) { if (!isset($this->cache[$key])) { if (!isset($this->mappings[$key])) { list($type, $name) = explode('.', $key); throw new InvalidArgumentException("No {$type} visitor has been mapped for {$name}"); } $this->cache[$key] = new $this->mappings[$key]; } return $this->cache[$key]; } } responseParser = $parser; return $this; } /** * Set the request serializer used with the command * * @param RequestSerializerInterface $serializer Request serializer * * @return self */ public function setRequestSerializer(RequestSerializerInterface $serializer) { $this->requestSerializer = $serializer; return $this; } /** * Get the request serializer used with the command * * @return RequestSerializerInterface */ public function getRequestSerializer() { if (!$this->requestSerializer) { // Use the default request serializer if none was found $this->requestSerializer = DefaultRequestSerializer::getInstance(); } return $this->requestSerializer; } /** * Get the response parser used for the operation * * @return ResponseParserInterface */ public function getResponseParser() { if (!$this->responseParser) { // Use the default response parser if none was found $this->responseParser = OperationResponseParser::getInstance(); } return $this->responseParser; } protected function build() { // Prepare and serialize the request $this->request = $this->getRequestSerializer()->prepare($this); } protected function process() { // Do not process the response if 'command.response_processing' is set to 'raw' $this->result = $this[self::RESPONSE_PROCESSING] == self::TYPE_RAW ? $this->request->getResponse() : $this->getResponseParser()->parse($this); } } factory = $factory; $this->schemaInModels = $schemaInModels; } /** * Add a location visitor to the command * * @param string $location Location to associate with the visitor * @param ResponseVisitorInterface $visitor Visitor to attach * * @return self */ public function addVisitor($location, ResponseVisitorInterface $visitor) { $this->factory->addResponseVisitor($location, $visitor); return $this; } protected function handleParsing(CommandInterface $command, Response $response, $contentType) { $operation = $command->getOperation(); $type = $operation->getResponseType(); $model = null; if ($type == OperationInterface::TYPE_MODEL) { $model = $operation->getServiceDescription()->getModel($operation->getResponseClass()); } elseif ($type == OperationInterface::TYPE_CLASS) { return $this->parseClass($command); } if (!$model) { // Return basic processing if the responseType is not model or the model cannot be found return parent::handleParsing($command, $response, $contentType); } elseif ($command[AbstractCommand::RESPONSE_PROCESSING] != AbstractCommand::TYPE_MODEL) { // Returns a model with no visiting if the command response processing is not model return new Model(parent::handleParsing($command, $response, $contentType)); } else { // Only inject the schema into the model if "schemaInModel" is true return new Model($this->visitResult($model, $command, $response), $this->schemaInModels ? $model : null); } } /** * Parse a class object * * @param CommandInterface $command Command to parse into an object * * @return mixed * @throws ResponseClassException */ protected function parseClass(CommandInterface $command) { // Emit the operation.parse_class event. If a listener injects a 'result' property, then that will be the result $event = new CreateResponseClassEvent(array('command' => $command)); $command->getClient()->getEventDispatcher()->dispatch('command.parse_response', $event); if ($result = $event->getResult()) { return $result; } $className = $command->getOperation()->getResponseClass(); if (!method_exists($className, 'fromCommand')) { throw new ResponseClassException("{$className} must exist and implement a static fromCommand() method"); } return $className::fromCommand($command); } /** * Perform transformations on the result array * * @param Parameter $model Model that defines the structure * @param CommandInterface $command Command that performed the operation * @param Response $response Response received * * @return array Returns the array of result data */ protected function visitResult(Parameter $model, CommandInterface $command, Response $response) { $foundVisitors = $result = $knownProps = array(); $props = $model->getProperties(); foreach ($props as $schema) { if ($location = $schema->getLocation()) { // Trigger the before method on the first found visitor of this type if (!isset($foundVisitors[$location])) { $foundVisitors[$location] = $this->factory->getResponseVisitor($location); $foundVisitors[$location]->before($command, $result); } } } // Visit additional properties when it is an actual schema if (($additional = $model->getAdditionalProperties()) instanceof Parameter) { $this->visitAdditionalProperties($model, $command, $response, $additional, $result, $foundVisitors); } // Apply the parameter value with the location visitor foreach ($props as $schema) { $knownProps[$schema->getName()] = 1; if ($location = $schema->getLocation()) { $foundVisitors[$location]->visit($command, $response, $schema, $result); } } // Remove any unknown and potentially unsafe top-level properties if ($additional === false) { $result = array_intersect_key($result, $knownProps); } // Call the after() method of each found visitor foreach ($foundVisitors as $visitor) { $visitor->after($command); } return $result; } protected function visitAdditionalProperties( Parameter $model, CommandInterface $command, Response $response, Parameter $additional, &$result, array &$foundVisitors ) { // Only visit when a location is specified if ($location = $additional->getLocation()) { if (!isset($foundVisitors[$location])) { $foundVisitors[$location] = $this->factory->getResponseVisitor($location); $foundVisitors[$location]->before($command, $result); } // Only traverse if an array was parsed from the before() visitors if (is_array($result)) { // Find each additional property foreach (array_keys($result) as $key) { // Check if the model actually knows this property. If so, then it is not additional if (!$model->getProperty($key)) { // Set the name to the key so that we can parse it with each visitor $additional->setName($key); $foundVisitors[$location]->visit($command, $response, $additional, $result); } } // Reset the additionalProperties name to null $additional->setName(null); } } } } true, 'httpMethod' => true, 'uri' => true, 'class' => true, 'responseClass' => true, 'responseType' => true, 'responseNotes' => true, 'notes' => true, 'summary' => true, 'documentationUrl' => true, 'deprecated' => true, 'data' => true, 'parameters' => true, 'additionalParameters' => true, 'errorResponses' => true ); /** @var array Parameters */ protected $parameters = array(); /** @var Parameter Additional parameters schema */ protected $additionalParameters; /** @var string Name of the command */ protected $name; /** @var string HTTP method */ protected $httpMethod; /** @var string This is a short summary of what the operation does */ protected $summary; /** @var string A longer text field to explain the behavior of the operation. */ protected $notes; /** @var string Reference URL providing more information about the operation */ protected $documentationUrl; /** @var string HTTP URI of the command */ protected $uri; /** @var string Class of the command object */ protected $class; /** @var string This is what is returned from the method */ protected $responseClass; /** @var string Type information about the response */ protected $responseType; /** @var string Information about the response returned by the operation */ protected $responseNotes; /** @var bool Whether or not the command is deprecated */ protected $deprecated; /** @var array Array of errors that could occur when running the command */ protected $errorResponses; /** @var ServiceDescriptionInterface */ protected $description; /** @var array Extra operation information */ protected $data; /** * Builds an Operation object using an array of configuration data: * - name: (string) Name of the command * - httpMethod: (string) HTTP method of the operation * - uri: (string) URI template that can create a relative or absolute URL * - class: (string) Concrete class that implements this command * - parameters: (array) Associative array of parameters for the command. {@see Parameter} for information. * - summary: (string) This is a short summary of what the operation does * - notes: (string) A longer text field to explain the behavior of the operation. * - documentationUrl: (string) Reference URL providing more information about the operation * - responseClass: (string) This is what is returned from the method. Can be a primitive, PSR-0 compliant * class name, or model. * - responseNotes: (string) Information about the response returned by the operation * - responseType: (string) One of 'primitive', 'class', 'model', or 'documentation'. If not specified, this * value will be automatically inferred based on whether or not there is a model matching the * name, if a matching PSR-0 compliant class name is found, or set to 'primitive' by default. * - deprecated: (bool) Set to true if this is a deprecated command * - errorResponses: (array) Errors that could occur when executing the command. Array of hashes, each with a * 'code' (the HTTP response code), 'phrase' (response reason phrase or description of the * error), and 'class' (a custom exception class that would be thrown if the error is * encountered). * - data: (array) Any extra data that might be used to help build or serialize the operation * - additionalParameters: (null|array) Parameter schema to use when an option is passed to the operation that is * not in the schema * * @param array $config Array of configuration data * @param ServiceDescriptionInterface $description Service description used to resolve models if $ref tags are found */ public function __construct(array $config = array(), ServiceDescriptionInterface $description = null) { $this->description = $description; // Get the intersection of the available properties and properties set on the operation foreach (array_intersect_key($config, self::$properties) as $key => $value) { $this->{$key} = $value; } $this->class = $this->class ?: self::DEFAULT_COMMAND_CLASS; $this->deprecated = (bool) $this->deprecated; $this->errorResponses = $this->errorResponses ?: array(); $this->data = $this->data ?: array(); if (!$this->responseClass) { $this->responseClass = 'array'; $this->responseType = 'primitive'; } elseif ($this->responseType) { // Set the response type to perform validation $this->setResponseType($this->responseType); } else { // A response class was set and no response type was set, so guess what the type is $this->inferResponseType(); } // Parameters need special handling when adding if ($this->parameters) { foreach ($this->parameters as $name => $param) { if ($param instanceof Parameter) { $param->setName($name)->setParent($this); } elseif (is_array($param)) { $param['name'] = $name; $this->addParam(new Parameter($param, $this->description)); } } } if ($this->additionalParameters) { if ($this->additionalParameters instanceof Parameter) { $this->additionalParameters->setParent($this); } elseif (is_array($this->additionalParameters)) { $this->setadditionalParameters(new Parameter($this->additionalParameters, $this->description)); } } } public function toArray() { $result = array(); // Grab valid properties and filter out values that weren't set foreach (array_keys(self::$properties) as $check) { if ($value = $this->{$check}) { $result[$check] = $value; } } // Remove the name property unset($result['name']); // Parameters need to be converted to arrays $result['parameters'] = array(); foreach ($this->parameters as $key => $param) { $result['parameters'][$key] = $param->toArray(); } // Additional parameters need to be cast to an array if ($this->additionalParameters instanceof Parameter) { $result['additionalParameters'] = $this->additionalParameters->toArray(); } return $result; } public function getServiceDescription() { return $this->description; } public function setServiceDescription(ServiceDescriptionInterface $description) { $this->description = $description; return $this; } public function getParams() { return $this->parameters; } public function getParamNames() { return array_keys($this->parameters); } public function hasParam($name) { return isset($this->parameters[$name]); } public function getParam($param) { return isset($this->parameters[$param]) ? $this->parameters[$param] : null; } /** * Add a parameter to the command * * @param Parameter $param Parameter to add * * @return self */ public function addParam(Parameter $param) { $this->parameters[$param->getName()] = $param; $param->setParent($this); return $this; } /** * Remove a parameter from the command * * @param string $name Name of the parameter to remove * * @return self */ public function removeParam($name) { unset($this->parameters[$name]); return $this; } public function getHttpMethod() { return $this->httpMethod; } /** * Set the HTTP method of the command * * @param string $httpMethod Method to set * * @return self */ public function setHttpMethod($httpMethod) { $this->httpMethod = $httpMethod; return $this; } public function getClass() { return $this->class; } /** * Set the concrete class of the command * * @param string $className Concrete class name * * @return self */ public function setClass($className) { $this->class = $className; return $this; } public function getName() { return $this->name; } /** * Set the name of the command * * @param string $name Name of the command * * @return self */ public function setName($name) { $this->name = $name; return $this; } public function getSummary() { return $this->summary; } /** * Set a short summary of what the operation does * * @param string $summary Short summary of the operation * * @return self */ public function setSummary($summary) { $this->summary = $summary; return $this; } public function getNotes() { return $this->notes; } /** * Set a longer text field to explain the behavior of the operation. * * @param string $notes Notes on the operation * * @return self */ public function setNotes($notes) { $this->notes = $notes; return $this; } public function getDocumentationUrl() { return $this->documentationUrl; } /** * Set the URL pointing to additional documentation on the command * * @param string $docUrl Documentation URL * * @return self */ public function setDocumentationUrl($docUrl) { $this->documentationUrl = $docUrl; return $this; } public function getResponseClass() { return $this->responseClass; } /** * Set what is returned from the method. Can be a primitive, class name, or model. For example: 'array', * 'Guzzle\\Foo\\Baz', or 'MyModelName' (to reference a model by ID). * * @param string $responseClass Type of response * * @return self */ public function setResponseClass($responseClass) { $this->responseClass = $responseClass; $this->inferResponseType(); return $this; } public function getResponseType() { return $this->responseType; } /** * Set qualifying information about the responseClass. One of 'primitive', 'class', 'model', or 'documentation' * * @param string $responseType Response type information * * @return self * @throws InvalidArgumentException */ public function setResponseType($responseType) { static $types = array( self::TYPE_PRIMITIVE => true, self::TYPE_CLASS => true, self::TYPE_MODEL => true, self::TYPE_DOCUMENTATION => true ); if (!isset($types[$responseType])) { throw new InvalidArgumentException('responseType must be one of ' . implode(', ', array_keys($types))); } $this->responseType = $responseType; return $this; } public function getResponseNotes() { return $this->responseNotes; } /** * Set notes about the response of the operation * * @param string $notes Response notes * * @return self */ public function setResponseNotes($notes) { $this->responseNotes = $notes; return $this; } public function getDeprecated() { return $this->deprecated; } /** * Set whether or not the command is deprecated * * @param bool $isDeprecated Set to true to mark as deprecated * * @return self */ public function setDeprecated($isDeprecated) { $this->deprecated = $isDeprecated; return $this; } public function getUri() { return $this->uri; } /** * Set the URI template of the command * * @param string $uri URI template to set * * @return self */ public function setUri($uri) { $this->uri = $uri; return $this; } public function getErrorResponses() { return $this->errorResponses; } /** * Add an error to the command * * @param string $code HTTP response code * @param string $reason HTTP response reason phrase or information about the error * @param string $class Exception class associated with the error * * @return self */ public function addErrorResponse($code, $reason, $class) { $this->errorResponses[] = array('code' => $code, 'reason' => $reason, 'class' => $class); return $this; } /** * Set all of the error responses of the operation * * @param array $errorResponses Hash of error name to a hash containing a code, reason, class * * @return self */ public function setErrorResponses(array $errorResponses) { $this->errorResponses = $errorResponses; return $this; } public function getData($name) { return isset($this->data[$name]) ? $this->data[$name] : null; } /** * Set a particular data point on the operation * * @param string $name Name of the data value * @param mixed $value Value to set * * @return self */ public function setData($name, $value) { $this->data[$name] = $value; return $this; } /** * Get the additionalParameters of the operation * * @return Parameter|null */ public function getAdditionalParameters() { return $this->additionalParameters; } /** * Set the additionalParameters of the operation * * @param Parameter|null $parameter Parameter to set * * @return self */ public function setAdditionalParameters($parameter) { if ($this->additionalParameters = $parameter) { $this->additionalParameters->setParent($this); } return $this; } /** * Infer the response type from the responseClass value */ protected function inferResponseType() { static $primitives = array('array' => 1, 'boolean' => 1, 'string' => 1, 'integer' => 1, '' => 1); if (isset($primitives[$this->responseClass])) { $this->responseType = self::TYPE_PRIMITIVE; } elseif ($this->description && $this->description->hasModel($this->responseClass)) { $this->responseType = self::TYPE_MODEL; } else { $this->responseType = self::TYPE_CLASS; } } } getModel($data['$ref'])) { $data = $model->toArray() + $data; } } elseif (isset($data['extends'])) { // If this parameter extends from another parameter then start with the actual data // union in the parent's data (e.g. actual supersedes parent) if ($extends = $description->getModel($data['extends'])) { $data += $extends->toArray(); } } } // Pull configuration data into the parameter foreach ($data as $key => $value) { $this->{$key} = $value; } $this->serviceDescription = $description; $this->required = (bool) $this->required; $this->data = (array) $this->data; if ($this->filters) { $this->setFilters((array) $this->filters); } if ($this->type == 'object' && $this->additionalProperties === null) { $this->additionalProperties = true; } } /** * Convert the object to an array * * @return array */ public function toArray() { static $checks = array('required', 'description', 'static', 'type', 'format', 'instanceOf', 'location', 'sentAs', 'pattern', 'minimum', 'maximum', 'minItems', 'maxItems', 'minLength', 'maxLength', 'data', 'enum', 'filters'); $result = array(); // Anything that is in the `Items` attribute of an array *must* include it's name if available if ($this->parent instanceof self && $this->parent->getType() == 'array' && isset($this->name)) { $result['name'] = $this->name; } foreach ($checks as $c) { if ($value = $this->{$c}) { $result[$c] = $value; } } if ($this->default !== null) { $result['default'] = $this->default; } if ($this->items !== null) { $result['items'] = $this->getItems()->toArray(); } if ($this->additionalProperties !== null) { $result['additionalProperties'] = $this->getAdditionalProperties(); if ($result['additionalProperties'] instanceof self) { $result['additionalProperties'] = $result['additionalProperties']->toArray(); } } if ($this->type == 'object' && $this->properties) { $result['properties'] = array(); foreach ($this->getProperties() as $name => $property) { $result['properties'][$name] = $property->toArray(); } } return $result; } /** * Get the default or static value of the command based on a value * * @param string $value Value that is currently set * * @return mixed Returns the value, a static value if one is present, or a default value */ public function getValue($value) { if ($this->static || ($this->default !== null && $value === null)) { return $this->default; } return $value; } /** * Run a value through the filters OR format attribute associated with the parameter * * @param mixed $value Value to filter * * @return mixed Returns the filtered value */ public function filter($value) { // Formats are applied exclusively and supersed filters if ($this->format) { return SchemaFormatter::format($this->format, $value); } // Convert Boolean values if ($this->type == 'boolean' && !is_bool($value)) { $value = filter_var($value, FILTER_VALIDATE_BOOLEAN); } // Apply filters to the value if ($this->filters) { foreach ($this->filters as $filter) { if (is_array($filter)) { // Convert complex filters that hold value place holders foreach ($filter['args'] as &$data) { if ($data == '@value') { $data = $value; } elseif ($data == '@api') { $data = $this; } } $value = call_user_func_array($filter['method'], $filter['args']); } else { $value = call_user_func($filter, $value); } } } return $value; } /** * Get the name of the parameter * * @return string */ public function getName() { return $this->name; } /** * Get the key of the parameter, where sentAs will supersede name if it is set * * @return string */ public function getWireName() { return $this->sentAs ?: $this->name; } /** * Set the name of the parameter * * @param string $name Name to set * * @return self */ public function setName($name) { $this->name = $name; return $this; } /** * Get the type(s) of the parameter * * @return string|array */ public function getType() { return $this->type; } /** * Set the type(s) of the parameter * * @param string|array $type Type of parameter or array of simple types used in a union * * @return self */ public function setType($type) { $this->type = $type; return $this; } /** * Get if the parameter is required * * @return bool */ public function getRequired() { return $this->required; } /** * Set if the parameter is required * * @param bool $isRequired Whether or not the parameter is required * * @return self */ public function setRequired($isRequired) { $this->required = (bool) $isRequired; return $this; } /** * Get the default value of the parameter * * @return string|null */ public function getDefault() { return $this->default; } /** * Set the default value of the parameter * * @param string|null $default Default value to set * * @return self */ public function setDefault($default) { $this->default = $default; return $this; } /** * Get the description of the parameter * * @return string|null */ public function getDescription() { return $this->description; } /** * Set the description of the parameter * * @param string $description Description * * @return self */ public function setDescription($description) { $this->description = $description; return $this; } /** * Get the minimum acceptable value for an integer * * @return int|null */ public function getMinimum() { return $this->minimum; } /** * Set the minimum acceptable value for an integer * * @param int|null $min Minimum * * @return self */ public function setMinimum($min) { $this->minimum = $min; return $this; } /** * Get the maximum acceptable value for an integer * * @return int|null */ public function getMaximum() { return $this->maximum; } /** * Set the maximum acceptable value for an integer * * @param int $max Maximum * * @return self */ public function setMaximum($max) { $this->maximum = $max; return $this; } /** * Get the minimum allowed length of a string value * * @return int */ public function getMinLength() { return $this->minLength; } /** * Set the minimum allowed length of a string value * * @param int|null $min Minimum * * @return self */ public function setMinLength($min) { $this->minLength = $min; return $this; } /** * Get the maximum allowed length of a string value * * @return int|null */ public function getMaxLength() { return $this->maxLength; } /** * Set the maximum allowed length of a string value * * @param int $max Maximum length * * @return self */ public function setMaxLength($max) { $this->maxLength = $max; return $this; } /** * Get the maximum allowed number of items in an array value * * @return int|null */ public function getMaxItems() { return $this->maxItems; } /** * Set the maximum allowed number of items in an array value * * @param int $max Maximum * * @return self */ public function setMaxItems($max) { $this->maxItems = $max; return $this; } /** * Get the minimum allowed number of items in an array value * * @return int */ public function getMinItems() { return $this->minItems; } /** * Set the minimum allowed number of items in an array value * * @param int|null $min Minimum * * @return self */ public function setMinItems($min) { $this->minItems = $min; return $this; } /** * Get the location of the parameter * * @return string|null */ public function getLocation() { return $this->location; } /** * Set the location of the parameter * * @param string|null $location Location of the parameter * * @return self */ public function setLocation($location) { $this->location = $location; return $this; } /** * Get the sentAs attribute of the parameter that used with locations to sentAs an attribute when it is being * applied to a location. * * @return string|null */ public function getSentAs() { return $this->sentAs; } /** * Set the sentAs attribute * * @param string|null $name Name of the value as it is sent over the wire * * @return self */ public function setSentAs($name) { $this->sentAs = $name; return $this; } /** * Retrieve a known property from the parameter by name or a data property by name. When not specific name value * is specified, all data properties will be returned. * * @param string|null $name Specify a particular property name to retrieve * * @return array|mixed|null */ public function getData($name = null) { if (!$name) { return $this->data; } if (isset($this->data[$name])) { return $this->data[$name]; } elseif (isset($this->{$name})) { return $this->{$name}; } return null; } /** * Set the extra data properties of the parameter or set a specific extra property * * @param string|array|null $nameOrData The name of a specific extra to set or an array of extras to set * @param mixed|null $data When setting a specific extra property, specify the data to set for it * * @return self */ public function setData($nameOrData, $data = null) { if (is_array($nameOrData)) { $this->data = $nameOrData; } else { $this->data[$nameOrData] = $data; } return $this; } /** * Get whether or not the default value can be changed * * @return mixed|null */ public function getStatic() { return $this->static; } /** * Set to true if the default value cannot be changed * * @param bool $static True or false * * @return self */ public function setStatic($static) { $this->static = (bool) $static; return $this; } /** * Get an array of filters used by the parameter * * @return array */ public function getFilters() { return $this->filters ?: array(); } /** * Set the array of filters used by the parameter * * @param array $filters Array of functions to use as filters * * @return self */ public function setFilters(array $filters) { $this->filters = array(); foreach ($filters as $filter) { $this->addFilter($filter); } return $this; } /** * Add a filter to the parameter * * @param string|array $filter Method to filter the value through * * @return self * @throws InvalidArgumentException */ public function addFilter($filter) { if (is_array($filter)) { if (!isset($filter['method'])) { throw new InvalidArgumentException('A [method] value must be specified for each complex filter'); } } if (!$this->filters) { $this->filters = array($filter); } else { $this->filters[] = $filter; } return $this; } /** * Get the parent object (an {@see OperationInterface} or {@see Parameter} * * @return OperationInterface|Parameter|null */ public function getParent() { return $this->parent; } /** * Set the parent object of the parameter * * @param OperationInterface|Parameter|null $parent Parent container of the parameter * * @return self */ public function setParent($parent) { $this->parent = $parent; return $this; } /** * Get the properties of the parameter * * @return array */ public function getProperties() { if (!$this->propertiesCache) { $this->propertiesCache = array(); foreach (array_keys($this->properties) as $name) { $this->propertiesCache[$name] = $this->getProperty($name); } } return $this->propertiesCache; } /** * Get a specific property from the parameter * * @param string $name Name of the property to retrieve * * @return null|Parameter */ public function getProperty($name) { if (!isset($this->properties[$name])) { return null; } if (!($this->properties[$name] instanceof self)) { $this->properties[$name]['name'] = $name; $this->properties[$name] = new static($this->properties[$name], $this->serviceDescription); $this->properties[$name]->setParent($this); } return $this->properties[$name]; } /** * Remove a property from the parameter * * @param string $name Name of the property to remove * * @return self */ public function removeProperty($name) { unset($this->properties[$name]); $this->propertiesCache = null; return $this; } /** * Add a property to the parameter * * @param Parameter $property Properties to set * * @return self */ public function addProperty(Parameter $property) { $this->properties[$property->getName()] = $property; $property->setParent($this); $this->propertiesCache = null; return $this; } /** * Get the additionalProperties value of the parameter * * @return bool|Parameter|null */ public function getAdditionalProperties() { if (is_array($this->additionalProperties)) { $this->additionalProperties = new static($this->additionalProperties, $this->serviceDescription); $this->additionalProperties->setParent($this); } return $this->additionalProperties; } /** * Set the additionalProperties value of the parameter * * @param bool|Parameter|null $additional Boolean to allow any, an Parameter to specify a schema, or false to disallow * * @return self */ public function setAdditionalProperties($additional) { $this->additionalProperties = $additional; return $this; } /** * Set the items data of the parameter * * @param Parameter|null $items Items to set * * @return self */ public function setItems(Parameter $items = null) { if ($this->items = $items) { $this->items->setParent($this); } return $this; } /** * Get the item data of the parameter * * @return Parameter|null */ public function getItems() { if (is_array($this->items)) { $this->items = new static($this->items, $this->serviceDescription); $this->items->setParent($this); } return $this->items; } /** * Get the class that the parameter must implement * * @return null|string */ public function getInstanceOf() { return $this->instanceOf; } /** * Set the class that the parameter must be an instance of * * @param string|null $instanceOf Class or interface name * * @return self */ public function setInstanceOf($instanceOf) { $this->instanceOf = $instanceOf; return $this; } /** * Get the enum of strings that are valid for the parameter * * @return array|null */ public function getEnum() { return $this->enum; } /** * Set the enum of strings that are valid for the parameter * * @param array|null $enum Array of strings or null * * @return self */ public function setEnum(array $enum = null) { $this->enum = $enum; return $this; } /** * Get the regex pattern that must match a value when the value is a string * * @return string */ public function getPattern() { return $this->pattern; } /** * Set the regex pattern that must match a value when the value is a string * * @param string $pattern Regex pattern * * @return self */ public function setPattern($pattern) { $this->pattern = $pattern; return $this; } /** * Get the format attribute of the schema * * @return string */ public function getFormat() { return $this->format; } /** * Set the format attribute of the schema * * @param string $format Format to set (e.g. date, date-time, timestamp, time, date-time-http) * * @return self */ public function setFormat($format) { $this->format = $format; return $this; } } setTimezone(self::getUtcTimeZone())->format($format); } throw new InvalidArgumentException('Date/Time values must be either a string, integer, or DateTime object'); } } castIntegerToStringType = $castIntegerToStringType; } public function validate(Parameter $param, &$value) { $this->errors = array(); $this->recursiveProcess($param, $value); if (empty($this->errors)) { return true; } else { sort($this->errors); return false; } } /** * Get the errors encountered while validating * * @return array */ public function getErrors() { return $this->errors ?: array(); } /** * Recursively validate a parameter * * @param Parameter $param API parameter being validated * @param mixed $value Value to validate and validate. The value may change during this validate. * @param string $path Current validation path (used for error reporting) * @param int $depth Current depth in the validation validate * * @return bool Returns true if valid, or false if invalid */ protected function recursiveProcess(Parameter $param, &$value, $path = '', $depth = 0) { // Update the value by adding default or static values $value = $param->getValue($value); $required = $param->getRequired(); // if the value is null and the parameter is not required or is static, then skip any further recursion if ((null === $value && !$required) || $param->getStatic()) { return true; } $type = $param->getType(); // Attempt to limit the number of times is_array is called by tracking if the value is an array $valueIsArray = is_array($value); // If a name is set then update the path so that validation messages are more helpful if ($name = $param->getName()) { $path .= "[{$name}]"; } if ($type == 'object') { // Objects are either associative arrays, ToArrayInterface, or some other object if ($param->getInstanceOf()) { $instance = $param->getInstanceOf(); if (!($value instanceof $instance)) { $this->errors[] = "{$path} must be an instance of {$instance}"; return false; } } // Determine whether or not this "value" has properties and should be traversed $traverse = $temporaryValue = false; // Convert the value to an array if (!$valueIsArray && $value instanceof ToArrayInterface) { $value = $value->toArray(); } if ($valueIsArray) { // Ensure that the array is associative and not numerically indexed if (isset($value[0])) { $this->errors[] = "{$path} must be an array of properties. Got a numerically indexed array."; return false; } $traverse = true; } elseif ($value === null) { // Attempt to let the contents be built up by default values if possible $value = array(); $temporaryValue = $valueIsArray = $traverse = true; } if ($traverse) { if ($properties = $param->getProperties()) { // if properties were found, the validate each property of the value foreach ($properties as $property) { $name = $property->getName(); if (isset($value[$name])) { $this->recursiveProcess($property, $value[$name], $path, $depth + 1); } else { $current = null; $this->recursiveProcess($property, $current, $path, $depth + 1); // Only set the value if it was populated with something if (null !== $current) { $value[$name] = $current; } } } } $additional = $param->getAdditionalProperties(); if ($additional !== true) { // If additional properties were found, then validate each against the additionalProperties attr. $keys = array_keys($value); // Determine the keys that were specified that were not listed in the properties of the schema $diff = array_diff($keys, array_keys($properties)); if (!empty($diff)) { // Determine which keys are not in the properties if ($additional instanceOf Parameter) { foreach ($diff as $key) { $this->recursiveProcess($additional, $value[$key], "{$path}[{$key}]", $depth); } } else { // if additionalProperties is set to false and there are additionalProperties in the values, then fail $keys = array_keys($value); $this->errors[] = sprintf('%s[%s] is not an allowed property', $path, reset($keys)); } } } // A temporary value will be used to traverse elements that have no corresponding input value. // This allows nested required parameters with default values to bubble up into the input. // Here we check if we used a temp value and nothing bubbled up, then we need to remote the value. if ($temporaryValue && empty($value)) { $value = null; $valueIsArray = false; } } } elseif ($type == 'array' && $valueIsArray && $param->getItems()) { foreach ($value as $i => &$item) { // Validate each item in an array against the items attribute of the schema $this->recursiveProcess($param->getItems(), $item, $path . "[{$i}]", $depth + 1); } } // If the value is required and the type is not null, then there is an error if the value is not set if ($required && $value === null && $type != 'null') { $message = "{$path} is " . ($param->getType() ? ('a required ' . implode(' or ', (array) $param->getType())) : 'required'); if ($param->getDescription()) { $message .= ': ' . $param->getDescription(); } $this->errors[] = $message; return false; } // Validate that the type is correct. If the type is string but an integer was passed, the class can be // instructed to cast the integer to a string to pass validation. This is the default behavior. if ($type && (!$type = $this->determineType($type, $value))) { if ($this->castIntegerToStringType && $param->getType() == 'string' && is_integer($value)) { $value = (string) $value; } else { $this->errors[] = "{$path} must be of type " . implode(' or ', (array) $param->getType()); } } // Perform type specific validation for strings, arrays, and integers if ($type == 'string') { // Strings can have enums which are a list of predefined values if (($enum = $param->getEnum()) && !in_array($value, $enum)) { $this->errors[] = "{$path} must be one of " . implode(' or ', array_map(function ($s) { return '"' . addslashes($s) . '"'; }, $enum)); } // Strings can have a regex pattern that the value must match if (($pattern = $param->getPattern()) && !preg_match($pattern, $value)) { $this->errors[] = "{$path} must match the following regular expression: {$pattern}"; } $strLen = null; if ($min = $param->getMinLength()) { $strLen = strlen($value); if ($strLen < $min) { $this->errors[] = "{$path} length must be greater than or equal to {$min}"; } } if ($max = $param->getMaxLength()) { if (($strLen ?: strlen($value)) > $max) { $this->errors[] = "{$path} length must be less than or equal to {$max}"; } } } elseif ($type == 'array') { $size = null; if ($min = $param->getMinItems()) { $size = count($value); if ($size < $min) { $this->errors[] = "{$path} must contain {$min} or more elements"; } } if ($max = $param->getMaxItems()) { if (($size ?: count($value)) > $max) { $this->errors[] = "{$path} must contain {$max} or fewer elements"; } } } elseif ($type == 'integer' || $type == 'number' || $type == 'numeric') { if (($min = $param->getMinimum()) && $value < $min) { $this->errors[] = "{$path} must be greater than or equal to {$min}"; } if (($max = $param->getMaximum()) && $value > $max) { $this->errors[] = "{$path} must be less than or equal to {$max}"; } } return empty($this->errors); } /** * From the allowable types, determine the type that the variable matches * * @param string $type Parameter type * @param mixed $value Value to determine the type * * @return string|bool Returns the matching type on */ protected function determineType($type, $value) { foreach ((array) $type as $t) { if ($t == 'string' && (is_string($value) || (is_object($value) && method_exists($value, '__toString')))) { return 'string'; } elseif ($t == 'object' && (is_array($value) || is_object($value))) { return 'object'; } elseif ($t == 'array' && is_array($value)) { return 'array'; } elseif ($t == 'integer' && is_integer($value)) { return 'integer'; } elseif ($t == 'boolean' && is_bool($value)) { return 'boolean'; } elseif ($t == 'number' && is_numeric($value)) { return 'number'; } elseif ($t == 'numeric' && is_numeric($value)) { return 'numeric'; } elseif ($t == 'null' && !$value) { return 'null'; } elseif ($t == 'any') { return 'any'; } } return false; } } load($config, $options); } /** * @param array $config Array of configuration data */ public function __construct(array $config = array()) { $this->fromArray($config); } public function serialize() { return json_encode($this->toArray()); } public function unserialize($json) { $this->operations = array(); $this->fromArray(json_decode($json, true)); } public function toArray() { $result = array( 'name' => $this->name, 'apiVersion' => $this->apiVersion, 'baseUrl' => $this->baseUrl, 'description' => $this->description ) + $this->extraData; $result['operations'] = array(); foreach ($this->getOperations() as $name => $operation) { $result['operations'][$operation->getName() ?: $name] = $operation->toArray(); } if (!empty($this->models)) { $result['models'] = array(); foreach ($this->models as $id => $model) { $result['models'][$id] = $model instanceof Parameter ? $model->toArray(): $model; } } return array_filter($result); } public function getBaseUrl() { return $this->baseUrl; } /** * Set the baseUrl of the description * * @param string $baseUrl Base URL of each operation * * @return self */ public function setBaseUrl($baseUrl) { $this->baseUrl = $baseUrl; return $this; } public function getOperations() { foreach (array_keys($this->operations) as $name) { $this->getOperation($name); } return $this->operations; } public function hasOperation($name) { return isset($this->operations[$name]); } public function getOperation($name) { // Lazily retrieve and build operations if (!isset($this->operations[$name])) { return null; } if (!($this->operations[$name] instanceof Operation)) { $this->operations[$name] = new Operation($this->operations[$name], $this); } return $this->operations[$name]; } /** * Add a operation to the service description * * @param OperationInterface $operation Operation to add * * @return self */ public function addOperation(OperationInterface $operation) { $this->operations[$operation->getName()] = $operation->setServiceDescription($this); return $this; } public function getModel($id) { if (!isset($this->models[$id])) { return null; } if (!($this->models[$id] instanceof Parameter)) { $this->models[$id] = new Parameter($this->models[$id] + array('name' => $id), $this); } return $this->models[$id]; } public function getModels() { // Ensure all models are converted into parameter objects foreach (array_keys($this->models) as $id) { $this->getModel($id); } return $this->models; } public function hasModel($id) { return isset($this->models[$id]); } /** * Add a model to the service description * * @param Parameter $model Model to add * * @return self */ public function addModel(Parameter $model) { $this->models[$model->getName()] = $model; return $this; } public function getApiVersion() { return $this->apiVersion; } public function getName() { return $this->name; } public function getDescription() { return $this->description; } public function getData($key) { return isset($this->extraData[$key]) ? $this->extraData[$key] : null; } public function setData($key, $value) { $this->extraData[$key] = $value; return $this; } /** * Initialize the state from an array * * @param array $config Configuration data * @throws InvalidArgumentException */ protected function fromArray(array $config) { // Keep a list of default keys used in service descriptions that is later used to determine extra data keys static $defaultKeys = array('name', 'models', 'apiVersion', 'baseUrl', 'description'); // Pull in the default configuration values foreach ($defaultKeys as $key) { if (isset($config[$key])) { $this->{$key} = $config[$key]; } } // Account for the Swagger name for Guzzle's baseUrl if (isset($config['basePath'])) { $this->baseUrl = $config['basePath']; } // Ensure that the models and operations properties are always arrays $this->models = (array) $this->models; $this->operations = (array) $this->operations; // We want to add operations differently than adding the other properties $defaultKeys[] = 'operations'; // Create operations for each operation if (isset($config['operations'])) { foreach ($config['operations'] as $name => $operation) { if (!($operation instanceof Operation) && !is_array($operation)) { throw new InvalidArgumentException('Invalid operation in service description: ' . gettype($operation)); } $this->operations[$name] = $operation; } } // Get all of the additional properties of the service description and store them in a data array foreach (array_diff(array_keys($config), $defaultKeys) as $key) { $this->extraData[$key] = $config[$key]; } } } $op) { $name = $op['name'] = isset($op['name']) ? $op['name'] : $name; // Extend other operations if (!empty($op['extends'])) { $this->resolveExtension($name, $op, $operations); } $op['parameters'] = isset($op['parameters']) ? $op['parameters'] : array(); $operations[$name] = $op; } } return new ServiceDescription(array( 'apiVersion' => isset($config['apiVersion']) ? $config['apiVersion'] : null, 'baseUrl' => isset($config['baseUrl']) ? $config['baseUrl'] : null, 'description' => isset($config['description']) ? $config['description'] : null, 'operations' => $operations, 'models' => isset($config['models']) ? $config['models'] : null ) + $config); } /** * @param string $name Name of the operation * @param array $op Operation value array * @param array $operations Currently loaded operations * @throws DescriptionBuilderException when extending a non-existent operation */ protected function resolveExtension($name, array &$op, array &$operations) { $resolved = array(); $original = empty($op['parameters']) ? false: $op['parameters']; $hasClass = !empty($op['class']); foreach ((array) $op['extends'] as $extendedCommand) { if (empty($operations[$extendedCommand])) { throw new DescriptionBuilderException("{$name} extends missing operation {$extendedCommand}"); } $toArray = $operations[$extendedCommand]; $resolved = empty($resolved) ? $toArray['parameters'] : array_merge($resolved, $toArray['parameters']); $op = $op + $toArray; if (!$hasClass && isset($toArray['class'])) { $op['class'] = $toArray['class']; } } $op['parameters'] = $original ? array_merge($resolved, $original) : $resolved; } } getMessage(), $e->getCode(), $e->getPrevious()); $ce->setSuccessfulRequests($e->getSuccessfulRequests()); $alreadyAddedExceptions = array(); foreach ($e->getFailedRequests() as $request) { if ($re = $e->getExceptionForFailedRequest($request)) { $alreadyAddedExceptions[] = $re; $ce->addFailedRequestWithException($request, $re); } else { $ce->addFailedRequest($request); } } // Add any exceptions that did not map to a request if (count($alreadyAddedExceptions) < count($e)) { foreach ($e as $ex) { if (!in_array($ex, $alreadyAddedExceptions)) { $ce->add($ex); } } } return $ce; } /** * Get all of the commands in the transfer * * @return array */ public function getAllCommands() { return array_merge($this->successfulCommands, $this->failedCommands); } /** * Add to the array of successful commands * * @param CommandInterface $command Successful command * * @return self */ public function addSuccessfulCommand(CommandInterface $command) { $this->successfulCommands[] = $command; return $this; } /** * Add to the array of failed commands * * @param CommandInterface $command Failed command * * @return self */ public function addFailedCommand(CommandInterface $command) { $this->failedCommands[] = $command; return $this; } /** * Get an array of successful commands * * @return array */ public function getSuccessfulCommands() { return $this->successfulCommands; } /** * Get an array of failed commands * * @return array */ public function getFailedCommands() { return $this->failedCommands; } /** * Get the Exception that caused the given $command to fail * * @param CommandInterface $command Failed command * * @return \Exception|null */ public function getExceptionForFailedCommand(CommandInterface $command) { return $this->getExceptionForFailedRequest($command->getRequest()); } } invalidCommands = $commands; parent::__construct( 'Encountered commands in a batch transfer that use inconsistent clients. The batching ' . 'strategy you use with a command transfer must divide command batches by client.' ); } /** * Get the invalid commands * * @return array */ public function getCommands() { return $this->invalidCommands; } } errors = $errors; } /** * Get any validation errors * * @return array */ public function getErrors() { return $this->errors; } } canBuild($command)) { throw new InvalidArgumentException('Iterator was not found for ' . $command->getName()); } $className = $this->getClassName($command); return new $className($command, $options); } public function canBuild(CommandInterface $command) { return (bool) $this->getClassName($command); } /** * Get the name of the class to instantiate for the command * * @param CommandInterface $command Command that is associated with the iterator * * @return string */ abstract protected function getClassName(CommandInterface $command); } factories = $factories; } public function build(CommandInterface $command, array $options = array()) { if (!($factory = $this->getFactory($command))) { throw new InvalidArgumentException('Iterator was not found for ' . $command->getName()); } return $factory->build($command, $options); } public function canBuild(CommandInterface $command) { return $this->getFactory($command) !== false; } /** * Add a factory to the composite factory * * @param ResourceIteratorFactoryInterface $factory Factory to add * * @return self */ public function addFactory(ResourceIteratorFactoryInterface $factory) { $this->factories[] = $factory; return $this; } /** * Get the factory that matches the command object * * @param CommandInterface $command Command retrieving the iterator for * * @return ResourceIteratorFactoryInterface|bool */ protected function getFactory(CommandInterface $command) { foreach ($this->factories as $factory) { if ($factory->canBuild($command)) { return $factory; } } return false; } } map = $map; } public function getClassName(CommandInterface $command) { $className = $command->getName(); if (isset($this->map[$className])) { return $this->map[$className]; } elseif (isset($this->map['*'])) { // If a wildcard was added, then always use that return $this->map['*']; } return null; } } data = $data; $this->structure = $structure; } /** * Get the structure of the model * * @return Parameter */ public function getStructure() { return $this->structure ?: new Parameter(); } /** * Provides debug information about the model object * * @return string */ public function __toString() { $output = 'Debug output of '; if ($this->structure) { $output .= $this->structure->getName() . ' '; } $output .= 'model'; $output = str_repeat('=', strlen($output)) . "\n" . $output . "\n" . str_repeat('=', strlen($output)) . "\n\n"; $output .= "Model data\n-----------\n\n"; $output .= "This data can be retrieved from the model object using the get() method of the model " . "(e.g. \$model->get(\$key)) or accessing the model like an associative array (e.g. \$model['key']).\n\n"; $lines = array_slice(explode("\n", trim(print_r($this->toArray(), true))), 2, -1); $output .= implode("\n", $lines); if ($this->structure) { $output .= "\n\nModel structure\n---------------\n\n"; $output .= "The following JSON document defines how the model was parsed from an HTTP response into the " . "associative array structure you see above.\n\n"; $output .= ' ' . json_encode($this->structure->toArray()) . "\n\n"; } return $output . "\n"; } } originalCommand = $command; // Parse options from the array of options $this->data = $data; $this->limit = array_key_exists('limit', $data) ? $data['limit'] : 0; $this->pageSize = array_key_exists('page_size', $data) ? $data['page_size'] : false; } /** * Get all of the resources as an array (Warning: this could issue a large number of requests) * * @return array */ public function toArray() { return iterator_to_array($this, false); } public function setLimit($limit) { $this->limit = $limit; $this->resetState(); return $this; } public function setPageSize($pageSize) { $this->pageSize = $pageSize; $this->resetState(); return $this; } /** * Get an option from the iterator * * @param string $key Key of the option to retrieve * * @return mixed|null Returns NULL if not set or the value if set */ public function get($key) { return array_key_exists($key, $this->data) ? $this->data[$key] : null; } /** * Set an option on the iterator * * @param string $key Key of the option to set * @param mixed $value Value to set for the option * * @return ResourceIterator */ public function set($key, $value) { $this->data[$key] = $value; return $this; } public function current() { return $this->resources ? current($this->resources) : false; } public function key() { return max(0, $this->iteratedCount - 1); } public function count() { return $this->retrievedCount; } /** * Get the total number of requests sent * * @return int */ public function getRequestCount() { return $this->requestCount; } /** * Rewind the Iterator to the first element and send the original command */ public function rewind() { // Use the original command $this->command = clone $this->originalCommand; $this->resetState(); $this->next(); } public function valid() { return !$this->invalid && (!$this->resources || $this->current() || $this->nextToken) && (!$this->limit || $this->iteratedCount < $this->limit + 1); } public function next() { $this->iteratedCount++; // Check if a new set of resources needs to be retrieved $sendRequest = false; if (!$this->resources) { $sendRequest = true; } else { // iterate over the internal array $current = next($this->resources); $sendRequest = $current === false && $this->nextToken && (!$this->limit || $this->iteratedCount < $this->limit + 1); } if ($sendRequest) { $this->dispatch('resource_iterator.before_send', array( 'iterator' => $this, 'resources' => $this->resources )); // Get a new command object from the original command $this->command = clone $this->originalCommand; // Send a request and retrieve the newly loaded resources $this->resources = $this->sendRequest(); $this->requestCount++; // If no resources were found, then the last request was not needed // and iteration must stop if (empty($this->resources)) { $this->invalid = true; } else { // Add to the number of retrieved resources $this->retrievedCount += count($this->resources); // Ensure that we rewind to the beginning of the array reset($this->resources); } $this->dispatch('resource_iterator.after_send', array( 'iterator' => $this, 'resources' => $this->resources )); } } /** * Retrieve the NextToken that can be used in other iterators. * * @return string Returns a NextToken */ public function getNextToken() { return $this->nextToken; } /** * Returns the value that should be specified for the page size for a request that will maintain any hard limits, * but still honor the specified pageSize if the number of items retrieved + pageSize < hard limit * * @return int Returns the page size of the next request. */ protected function calculatePageSize() { if ($this->limit && $this->iteratedCount + $this->pageSize > $this->limit) { return 1 + ($this->limit - $this->iteratedCount); } return (int) $this->pageSize; } /** * Reset the internal state of the iterator without triggering a rewind() */ protected function resetState() { $this->iteratedCount = 0; $this->retrievedCount = 0; $this->nextToken = false; $this->resources = null; $this->invalid = false; } /** * Send a request to retrieve the next page of results. Hook for subclasses to implement. * * @return array Returns the newly loaded resources */ abstract protected function sendRequest(); } iterator = $iterator; $this->callback = $callback; Version::warn(__CLASS__ . ' is deprecated'); } /** * Apply the callback to the contents of the resource iterator * * @param int $perBatch The number of records to group per batch transfer * * @return int Returns the number of iterated resources */ public function apply($perBatch = 50) { $this->iterated = $this->batches = $batches = 0; $that = $this; $it = $this->iterator; $callback = $this->callback; $batch = BatchBuilder::factory() ->createBatchesWith(new BatchSizeDivisor($perBatch)) ->transferWith(new BatchClosureTransfer(function (array $batch) use ($that, $callback, &$batches, $it) { $batches++; $that->dispatch('iterator_batch.before_batch', array('iterator' => $it, 'batch' => $batch)); call_user_func_array($callback, array($it, $batch)); $that->dispatch('iterator_batch.after_batch', array('iterator' => $it, 'batch' => $batch)); })) ->autoFlushAt($perBatch) ->build(); $this->dispatch('iterator_batch.created_batch', array('batch' => $batch)); foreach ($this->iterator as $resource) { $this->iterated++; $batch->add($resource); } $batch->flush(); $this->batches = $batches; return $this->iterated; } /** * Get the total number of batches sent * * @return int */ public function getBatchCount() { return $this->batches; } /** * Get the total number of iterated resources * * @return int */ public function getIteratedCount() { return $this->iterated; } } AbcFoo). */ class ResourceIteratorClassFactory extends AbstractResourceIteratorFactory { /** @var array List of namespaces used to look for classes */ protected $namespaces; /** @var InflectorInterface Inflector used to determine class names */ protected $inflector; /** * @param string|array $namespaces List of namespaces for iterator objects * @param InflectorInterface $inflector Inflector used to resolve class names */ public function __construct($namespaces = array(), InflectorInterface $inflector = null) { $this->namespaces = (array) $namespaces; $this->inflector = $inflector ?: Inflector::getDefault(); } /** * Registers a namespace to check for Iterators * * @param string $namespace Namespace which contains Iterator classes * * @return self */ public function registerNamespace($namespace) { array_unshift($this->namespaces, $namespace); return $this; } protected function getClassName(CommandInterface $command) { $iteratorName = $this->inflector->camel($command->getName()) . 'Iterator'; // Determine the name of the class to load foreach ($this->namespaces as $namespace) { $potentialClassName = $namespace . '\\' . $iteratorName; if (class_exists($potentialClassName)) { return $potentialClassName; } } return false; } } contextOptions = stream_context_get_options($context); $this->context = $context; } elseif (is_array($context) || !$context) { $this->contextOptions = $context; $this->createContext($params); } elseif ($context) { throw new InvalidArgumentException('$context must be an array or resource'); } // Dispatch the before send event $request->dispatch('request.before_send', array( 'request' => $request, 'context' => $this->context, 'context_options' => $this->contextOptions )); $this->setUrl($request); $this->addDefaultContextOptions($request); $this->addSslOptions($request); $this->addBodyOptions($request); $this->addProxyOptions($request); // Create the file handle but silence errors return $this->createStream($params) ->setCustomData('request', $request) ->setCustomData('response_headers', $this->getLastResponseHeaders()); } /** * Set an option on the context and the internal options array * * @param string $wrapper Stream wrapper name of http * @param string $name Context name * @param mixed $value Context value * @param bool $overwrite Set to true to overwrite an existing value */ protected function setContextValue($wrapper, $name, $value, $overwrite = false) { if (!isset($this->contextOptions[$wrapper])) { $this->contextOptions[$wrapper] = array($name => $value); } elseif (!$overwrite && isset($this->contextOptions[$wrapper][$name])) { return; } $this->contextOptions[$wrapper][$name] = $value; stream_context_set_option($this->context, $wrapper, $name, $value); } /** * Create a stream context * * @param array $params Parameter array */ protected function createContext(array $params) { $options = $this->contextOptions; $this->context = $this->createResource(function () use ($params, $options) { return stream_context_create($options, $params); }); } /** * Get the last response headers received by the HTTP request * * @return array */ public function getLastResponseHeaders() { return $this->lastResponseHeaders; } /** * Adds the default context options to the stream context options * * @param RequestInterface $request Request */ protected function addDefaultContextOptions(RequestInterface $request) { $this->setContextValue('http', 'method', $request->getMethod()); $headers = $request->getHeaderLines(); // "Connection: close" is required to get streams to work in HTTP 1.1 if (!$request->hasHeader('Connection')) { $headers[] = 'Connection: close'; } $this->setContextValue('http', 'header', $headers); $this->setContextValue('http', 'protocol_version', $request->getProtocolVersion()); $this->setContextValue('http', 'ignore_errors', true); } /** * Set the URL to use with the factory * * @param RequestInterface $request Request that owns the URL */ protected function setUrl(RequestInterface $request) { $this->url = $request->getUrl(true); // Check for basic Auth username if ($request->getUsername()) { $this->url->setUsername($request->getUsername()); } // Check for basic Auth password if ($request->getPassword()) { $this->url->setPassword($request->getPassword()); } } /** * Add SSL options to the stream context * * @param RequestInterface $request Request */ protected function addSslOptions(RequestInterface $request) { if ($request->getCurlOptions()->get(CURLOPT_SSL_VERIFYPEER)) { $this->setContextValue('ssl', 'verify_peer', true, true); if ($cafile = $request->getCurlOptions()->get(CURLOPT_CAINFO)) { $this->setContextValue('ssl', 'cafile', $cafile, true); } } else { $this->setContextValue('ssl', 'verify_peer', false, true); } } /** * Add body (content) specific options to the context options * * @param RequestInterface $request */ protected function addBodyOptions(RequestInterface $request) { // Add the content for the request if needed if (!($request instanceof EntityEnclosingRequestInterface)) { return; } if (count($request->getPostFields())) { $this->setContextValue('http', 'content', (string) $request->getPostFields(), true); } elseif ($request->getBody()) { $this->setContextValue('http', 'content', (string) $request->getBody(), true); } // Always ensure a content-length header is sent if (isset($this->contextOptions['http']['content'])) { $headers = isset($this->contextOptions['http']['header']) ? $this->contextOptions['http']['header'] : array(); $headers[] = 'Content-Length: ' . strlen($this->contextOptions['http']['content']); $this->setContextValue('http', 'header', $headers, true); } } /** * Add proxy parameters to the context if needed * * @param RequestInterface $request Request */ protected function addProxyOptions(RequestInterface $request) { if ($proxy = $request->getCurlOptions()->get(CURLOPT_PROXY)) { $this->setContextValue('http', 'proxy', $proxy); } } /** * Create the stream for the request with the context options * * @param array $params Parameters of the stream * * @return StreamInterface */ protected function createStream(array $params) { $http_response_header = null; $url = $this->url; $context = $this->context; $fp = $this->createResource(function () use ($context, $url, &$http_response_header) { return fopen((string) $url, 'r', false, $context); }); // Determine the class to instantiate $className = isset($params['stream_class']) ? $params['stream_class'] : __NAMESPACE__ . '\\Stream'; /** @var $stream StreamInterface */ $stream = new $className($fp); // Track the response headers of the request if (isset($http_response_header)) { $this->lastResponseHeaders = $http_response_header; $this->processResponseHeaders($stream); } return $stream; } /** * Process response headers * * @param StreamInterface $stream */ protected function processResponseHeaders(StreamInterface $stream) { // Set the size on the stream if it was returned in the response foreach ($this->lastResponseHeaders as $header) { if ((stripos($header, 'Content-Length:')) === 0) { $stream->setSize(trim(substr($header, 15))); } } } /** * Create a resource and check to ensure it was created successfully * * @param callable $callback Closure to invoke that must return a valid resource * * @return resource * @throws RuntimeException on error */ protected function createResource($callback) { // Turn off error reporting while we try to initiate the request $level = error_reporting(0); $resource = call_user_func($callback); error_reporting($level); // If the resource could not be created, then grab the last error and throw an exception if (false === $resource) { $message = 'Error creating resource. '; foreach (error_get_last() as $key => $value) { $message .= "[{$key}] {$value} "; } throw new RuntimeException(trim($message)); } return $resource; } } array( 'r' => true, 'w+' => true, 'r+' => true, 'x+' => true, 'c+' => true, 'rb' => true, 'w+b' => true, 'r+b' => true, 'x+b' => true, 'c+b' => true, 'rt' => true, 'w+t' => true, 'r+t' => true, 'x+t' => true, 'c+t' => true, 'a+' => true ), 'write' => array( 'w' => true, 'w+' => true, 'rw' => true, 'r+' => true, 'x+' => true, 'c+' => true, 'wb' => true, 'w+b' => true, 'r+b' => true, 'x+b' => true, 'c+b' => true, 'w+t' => true, 'r+t' => true, 'x+t' => true, 'c+t' => true, 'a' => true, 'a+' => true ) ); /** * @param resource $stream Stream resource to wrap * @param int $size Size of the stream in bytes. Only pass if the size cannot be obtained from the stream. * * @throws InvalidArgumentException if the stream is not a stream resource */ public function __construct($stream, $size = null) { $this->setStream($stream, $size); } /** * Closes the stream when the helper is destructed */ public function __destruct() { $this->close(); } public function __toString() { if (!$this->isReadable() || (!$this->isSeekable() && $this->isConsumed())) { return ''; } $originalPos = $this->ftell(); $body = stream_get_contents($this->stream, -1, 0); $this->seek($originalPos); return $body; } public function close() { if (is_resource($this->stream)) { fclose($this->stream); } $this->cache[self::IS_READABLE] = false; $this->cache[self::IS_WRITABLE] = false; } /** * Calculate a hash of a Stream * * @param StreamInterface $stream Stream to calculate the hash for * @param string $algo Hash algorithm (e.g. md5, crc32, etc) * @param bool $rawOutput Whether or not to use raw output * * @return bool|string Returns false on failure or a hash string on success */ public static function getHash(StreamInterface $stream, $algo, $rawOutput = false) { $pos = $stream->ftell(); if (!$stream->seek(0)) { return false; } $ctx = hash_init($algo); while ($data = $stream->read(8192)) { hash_update($ctx, $data); } $out = hash_final($ctx, (bool) $rawOutput); $stream->seek($pos); return $out; } public function getMetaData($key = null) { $meta = stream_get_meta_data($this->stream); return !$key ? $meta : (array_key_exists($key, $meta) ? $meta[$key] : null); } public function getStream() { return $this->stream; } public function setStream($stream, $size = null) { if (!is_resource($stream)) { throw new InvalidArgumentException('Stream must be a resource'); } $this->size = $size; $this->stream = $stream; $this->rebuildCache(); return $this; } public function detachStream() { $this->stream = null; return $this; } public function getWrapper() { return $this->cache[self::WRAPPER_TYPE]; } public function getWrapperData() { return $this->getMetaData('wrapper_data') ?: array(); } public function getStreamType() { return $this->cache[self::STREAM_TYPE]; } public function getUri() { return $this->cache['uri']; } public function getSize() { if ($this->size !== null) { return $this->size; } // If the stream is a file based stream and local, then use fstat clearstatcache(true, $this->cache['uri']); $stats = fstat($this->stream); if (isset($stats['size'])) { $this->size = $stats['size']; return $this->size; } elseif ($this->cache[self::IS_READABLE] && $this->cache[self::SEEKABLE]) { // Only get the size based on the content if the the stream is readable and seekable $pos = $this->ftell(); $this->size = strlen((string) $this); $this->seek($pos); return $this->size; } return false; } public function isReadable() { return $this->cache[self::IS_READABLE]; } public function isRepeatable() { return $this->cache[self::IS_READABLE] && $this->cache[self::SEEKABLE]; } public function isWritable() { return $this->cache[self::IS_WRITABLE]; } public function isConsumed() { return feof($this->stream); } public function feof() { return $this->isConsumed(); } public function isLocal() { return $this->cache[self::IS_LOCAL]; } public function isSeekable() { return $this->cache[self::SEEKABLE]; } public function setSize($size) { $this->size = $size; return $this; } public function seek($offset, $whence = SEEK_SET) { return $this->cache[self::SEEKABLE] ? fseek($this->stream, $offset, $whence) === 0 : false; } public function read($length) { return fread($this->stream, $length); } public function write($string) { // We can't know the size after writing anything $this->size = null; return fwrite($this->stream, $string); } public function ftell() { return ftell($this->stream); } public function rewind() { return $this->seek(0); } public function readLine($maxLength = null) { if (!$this->cache[self::IS_READABLE]) { return false; } else { return $maxLength ? fgets($this->getStream(), $maxLength) : fgets($this->getStream()); } } public function setCustomData($key, $value) { $this->customData[$key] = $value; return $this; } public function getCustomData($key) { return isset($this->customData[$key]) ? $this->customData[$key] : null; } /** * Reprocess stream metadata */ protected function rebuildCache() { $this->cache = stream_get_meta_data($this->stream); $this->cache[self::IS_LOCAL] = stream_is_local($this->stream); $this->cache[self::IS_READABLE] = isset(self::$readWriteHash['read'][$this->cache['mode']]); $this->cache[self::IS_WRITABLE] = isset(self::$readWriteHash['write'][$this->cache['mode']]); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Formatter; use Monolog\Logger; /** * Formats a log message according to the ChromePHP array format * * @author Christophe Coevoet */ class ChromePHPFormatter implements FormatterInterface { /** * Translates Monolog log levels to Wildfire levels. */ private $logLevels = array( Logger::DEBUG => 'log', Logger::INFO => 'info', Logger::NOTICE => 'info', Logger::WARNING => 'warn', Logger::ERROR => 'error', Logger::CRITICAL => 'error', Logger::ALERT => 'error', Logger::EMERGENCY => 'error', ); /** * {@inheritdoc} */ public function format(array $record) { // Retrieve the line and file if set and remove them from the formatted extra $backtrace = 'unknown'; if (isset($record['extra']['file']) && isset($record['extra']['line'])) { $backtrace = $record['extra']['file'].' : '.$record['extra']['line']; unset($record['extra']['file']); unset($record['extra']['line']); } $message = array('message' => $record['message']); if ($record['context']) { $message['context'] = $record['context']; } if ($record['extra']) { $message['extra'] = $record['extra']; } if (count($message) === 1) { $message = reset($message); } return array( $record['channel'], $message, $backtrace, $this->logLevels[$record['level']], ); } public function formatBatch(array $records) { $formatted = array(); foreach ($records as $record) { $formatted[] = $this->format($record); } return $formatted; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Formatter; /** * Interface for formatters * * @author Jordi Boggiano */ interface FormatterInterface { /** * Formats a log record. * * @param array $record A record to format * @return mixed The formatted record */ public function format(array $record); /** * Formats a set of log records. * * @param array $records A set of records to format * @return mixed The formatted set of records */ public function formatBatch(array $records); } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Formatter; use Monolog\Logger; use Gelf\Message; /** * Serializes a log message to GELF * @see http://www.graylog2.org/about/gelf * * @author Matt Lehner */ class GelfMessageFormatter extends NormalizerFormatter { /** * @var string the name of the system for the Gelf log message */ protected $systemName; /** * @var string a prefix for 'extra' fields from the Monolog record (optional) */ protected $extraPrefix; /** * @var string a prefix for 'context' fields from the Monolog record (optional) */ protected $contextPrefix; /** * Translates Monolog log levels to Graylog2 log priorities. */ private $logLevels = array( Logger::DEBUG => 7, Logger::INFO => 6, Logger::NOTICE => 5, Logger::WARNING => 4, Logger::ERROR => 3, Logger::CRITICAL => 2, Logger::ALERT => 1, Logger::EMERGENCY => 0, ); public function __construct($systemName = null, $extraPrefix = null, $contextPrefix = 'ctxt_') { parent::__construct('U.u'); $this->systemName = $systemName ?: gethostname(); $this->extraPrefix = $extraPrefix; $this->contextPrefix = $contextPrefix; } /** * {@inheritdoc} */ public function format(array $record) { $record = parent::format($record); $message = new Message(); $message ->setTimestamp($record['datetime']) ->setShortMessage((string) $record['message']) ->setFacility($record['channel']) ->setHost($this->systemName) ->setLine(isset($record['extra']['line']) ? $record['extra']['line'] : null) ->setFile(isset($record['extra']['file']) ? $record['extra']['file'] : null) ->setLevel($this->logLevels[$record['level']]); // Do not duplicate these values in the additional fields unset($record['extra']['line']); unset($record['extra']['file']); foreach ($record['extra'] as $key => $val) { $message->setAdditional($this->extraPrefix . $key, is_scalar($val) ? $val : $this->toJson($val)); } foreach ($record['context'] as $key => $val) { $message->setAdditional($this->contextPrefix . $key, is_scalar($val) ? $val : $this->toJson($val)); } return $message; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Formatter; /** * Encodes whatever record data is passed to it as json * * This can be useful to log to databases or remote APIs * * @author Jordi Boggiano */ class JsonFormatter implements FormatterInterface { /** * {@inheritdoc} */ public function format(array $record) { return json_encode($record); } /** * {@inheritdoc} */ public function formatBatch(array $records) { return json_encode($records); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Formatter; /** * Formats incoming records into a one-line string * * This is especially useful for logging to files * * @author Jordi Boggiano * @author Christophe Coevoet */ class LineFormatter extends NormalizerFormatter { const SIMPLE_FORMAT = "[%datetime%] %channel%.%level_name%: %message% %context% %extra%\n"; protected $format; /** * @param string $format The format of the message * @param string $dateFormat The format of the timestamp: one supported by DateTime::format */ public function __construct($format = null, $dateFormat = null) { $this->format = $format ?: static::SIMPLE_FORMAT; parent::__construct($dateFormat); } /** * {@inheritdoc} */ public function format(array $record) { $vars = parent::format($record); $output = $this->format; foreach ($vars['extra'] as $var => $val) { if (false !== strpos($output, '%extra.'.$var.'%')) { $output = str_replace('%extra.'.$var.'%', $this->convertToString($val), $output); unset($vars['extra'][$var]); } } foreach ($vars as $var => $val) { $output = str_replace('%'.$var.'%', $this->convertToString($val), $output); } return $output; } public function formatBatch(array $records) { $message = ''; foreach ($records as $record) { $message .= $this->format($record); } return $message; } protected function normalize($data) { if (is_bool($data) || is_null($data)) { return var_export($data, true); } if ($data instanceof \Exception) { return '[object] ('.get_class($data).': '.$data->getMessage().' at '.$data->getFile().':'.$data->getLine().')'; } return parent::normalize($data); } protected function convertToString($data) { if (null === $data || is_scalar($data)) { return (string) $data; } $data = $this->normalize($data); if (version_compare(PHP_VERSION, '5.4.0', '>=')) { return $this->toJson($data); } return str_replace('\\/', '/', json_encode($data)); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Formatter; /** * Serializes a log message to Logstash Event Format * * @see http://logstash.net/ * @see https://github.com/logstash/logstash/blob/master/lib/logstash/event.rb * * @author Tim Mower */ class LogstashFormatter extends NormalizerFormatter { /** * @var string the name of the system for the Logstash log message, used to fill the @source field */ protected $systemName; /** * @var string an application name for the Logstash log message, used to fill the @type field */ protected $applicationName; /** * @var string a prefix for 'extra' fields from the Monolog record (optional) */ protected $extraPrefix; /** * @var string a prefix for 'context' fields from the Monolog record (optional) */ protected $contextPrefix; /** * @param string $applicationName the application that sends the data, used as the "type" field of logstash * @param string $systemName the system/machine name, used as the "source" field of logstash, defaults to the hostname of the machine * @param string $extraPrefix prefix for extra keys inside logstash "fields" * @param string $contextPrefix prefix for context keys inside logstash "fields", defaults to ctxt_ */ public function __construct($applicationName, $systemName = null, $extraPrefix = null, $contextPrefix = 'ctxt_') { //log stash requires a ISO 8601 format date parent::__construct('c'); $this->systemName = $systemName ?: gethostname(); $this->applicationName = $applicationName; $this->extraPrefix = $extraPrefix; $this->contextPrefix = $contextPrefix; } /** * {@inheritdoc} */ public function format(array $record) { $record = parent::format($record); $message = array( '@timestamp' => $record['datetime'], '@message' => $record['message'], '@tags' => array($record['channel']), '@source' => $this->systemName ); if ($this->applicationName) { $message['@type'] = $this->applicationName; } $message['@fields'] = array(); $message['@fields']['channel'] = $record['channel']; $message['@fields']['level'] = $record['level']; if (isset($record['extra']['server'])) { $message['@source_host'] = $record['extra']['server']; } if (isset($record['extra']['url'])) { $message['@source_path'] = $record['extra']['url']; } foreach ($record['extra'] as $key => $val) { $message['@fields'][$this->extraPrefix . $key] = $val; } foreach ($record['context'] as $key => $val) { $message['@fields'][$this->contextPrefix . $key] = $val; } return json_encode($message) . "\n"; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Formatter; /** * Normalizes incoming records to remove objects/resources so it's easier to dump to various targets * * @author Jordi Boggiano */ class NormalizerFormatter implements FormatterInterface { const SIMPLE_DATE = "Y-m-d H:i:s"; protected $dateFormat; /** * @param string $dateFormat The format of the timestamp: one supported by DateTime::format */ public function __construct($dateFormat = null) { $this->dateFormat = $dateFormat ?: static::SIMPLE_DATE; } /** * {@inheritdoc} */ public function format(array $record) { return $this->normalize($record); } /** * {@inheritdoc} */ public function formatBatch(array $records) { foreach ($records as $key => $record) { $records[$key] = $this->format($record); } return $records; } protected function normalize($data) { if (null === $data || is_scalar($data)) { return $data; } if (is_array($data) || $data instanceof \Traversable) { $normalized = array(); foreach ($data as $key => $value) { $normalized[$key] = $this->normalize($value); } return $normalized; } if ($data instanceof \DateTime) { return $data->format($this->dateFormat); } if (is_object($data)) { return sprintf("[object] (%s: %s)", get_class($data), $this->toJson($data, true)); } if (is_resource($data)) { return '[resource]'; } return '[unknown('.gettype($data).')]'; } protected function toJson($data, $ignoreErrors = false) { // suppress json_encode errors since it's twitchy with some inputs if ($ignoreErrors) { if (version_compare(PHP_VERSION, '5.4.0', '>=')) { return @json_encode($data, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE); } return @json_encode($data); } if (version_compare(PHP_VERSION, '5.4.0', '>=')) { return json_encode($data, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE); } return json_encode($data); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Formatter; use Monolog\Logger; /** * Serializes a log message according to Wildfire's header requirements * * @author Eric Clemmons (@ericclemmons) * @author Christophe Coevoet * @author Kirill chEbba Chebunin */ class WildfireFormatter extends NormalizerFormatter { /** * Translates Monolog log levels to Wildfire levels. */ private $logLevels = array( Logger::DEBUG => 'LOG', Logger::INFO => 'INFO', Logger::NOTICE => 'INFO', Logger::WARNING => 'WARN', Logger::ERROR => 'ERROR', Logger::CRITICAL => 'ERROR', Logger::ALERT => 'ERROR', Logger::EMERGENCY => 'ERROR', ); /** * {@inheritdoc} */ public function format(array $record) { // Retrieve the line and file if set and remove them from the formatted extra $file = $line = ''; if (isset($record['extra']['file'])) { $file = $record['extra']['file']; unset($record['extra']['file']); } if (isset($record['extra']['line'])) { $line = $record['extra']['line']; unset($record['extra']['line']); } $record = $this->normalize($record); $message = array('message' => $record['message']); $handleError = false; if ($record['context']) { $message['context'] = $record['context']; $handleError = true; } if ($record['extra']) { $message['extra'] = $record['extra']; $handleError = true; } if (count($message) === 1) { $message = reset($message); } // Create JSON object describing the appearance of the message in the console $json = $this->toJson(array( array( 'Type' => $this->logLevels[$record['level']], 'File' => $file, 'Line' => $line, 'Label' => $record['channel'], ), $message, ), $handleError); // The message itself is a serialization of the above JSON object + it's length return sprintf( '%s|%s|', strlen($json), $json ); } public function formatBatch(array $records) { throw new \BadMethodCallException('Batch formatting does not make sense for the WildfireFormatter'); } protected function normalize($data) { if (is_object($data) && !$data instanceof \DateTime) { return $data; } return parent::normalize($data); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; use Monolog\Formatter\FormatterInterface; use Monolog\Formatter\LineFormatter; /** * Base Handler class providing the Handler structure * * @author Jordi Boggiano */ abstract class AbstractHandler implements HandlerInterface { protected $level = Logger::DEBUG; protected $bubble = false; /** * @var FormatterInterface */ protected $formatter; protected $processors = array(); /** * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct($level = Logger::DEBUG, $bubble = true) { $this->level = $level; $this->bubble = $bubble; } /** * {@inheritdoc} */ public function isHandling(array $record) { return $record['level'] >= $this->level; } /** * {@inheritdoc} */ public function handleBatch(array $records) { foreach ($records as $record) { $this->handle($record); } } /** * Closes the handler. * * This will be called automatically when the object is destroyed */ public function close() { } /** * {@inheritdoc} */ public function pushProcessor($callback) { if (!is_callable($callback)) { throw new \InvalidArgumentException('Processors must be valid callables (callback or object with an __invoke method), '.var_export($callback, true).' given'); } array_unshift($this->processors, $callback); } /** * {@inheritdoc} */ public function popProcessor() { if (!$this->processors) { throw new \LogicException('You tried to pop from an empty processor stack.'); } return array_shift($this->processors); } /** * {@inheritdoc} */ public function setFormatter(FormatterInterface $formatter) { $this->formatter = $formatter; } /** * {@inheritdoc} */ public function getFormatter() { if (!$this->formatter) { $this->formatter = $this->getDefaultFormatter(); } return $this->formatter; } /** * Sets minimum logging level at which this handler will be triggered. * * @param integer $level */ public function setLevel($level) { $this->level = $level; } /** * Gets minimum logging level at which this handler will be triggered. * * @return integer */ public function getLevel() { return $this->level; } /** * Sets the bubbling behavior. * * @param Boolean $bubble True means that bubbling is not permitted. * False means that this handler allows bubbling. */ public function setBubble($bubble) { $this->bubble = $bubble; } /** * Gets the bubbling behavior. * * @return Boolean True means that bubbling is not permitted. * False means that this handler allows bubbling. */ public function getBubble() { return $this->bubble; } public function __destruct() { try { $this->close(); } catch (\Exception $e) { // do nothing } } /** * Gets the default formatter. * * @return FormatterInterface */ protected function getDefaultFormatter() { return new LineFormatter(); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; /** * Base Handler class providing the Handler structure * * Classes extending it should (in most cases) only implement write($record) * * @author Jordi Boggiano * @author Christophe Coevoet */ abstract class AbstractProcessingHandler extends AbstractHandler { /** * {@inheritdoc} */ public function handle(array $record) { if ($record['level'] < $this->level) { return false; } $record = $this->processRecord($record); $record['formatted'] = $this->getFormatter()->format($record); $this->write($record); return false === $this->bubble; } /** * Writes the record down to the log of the implementing handler * * @param array $record * @return void */ abstract protected function write(array $record); /** * Processes a record. * * @param array $record * @return array */ protected function processRecord(array $record) { if ($this->processors) { foreach ($this->processors as $processor) { $record = call_user_func($processor, $record); } } return $record; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; use Monolog\Formatter\JsonFormatter; class AmqpHandler extends AbstractProcessingHandler { /** * @var \AMQPExchange $exchange */ protected $exchange; /** * @param \AMQPExchange $exchange AMQP exchange, ready for use * @param string $exchangeName * @param int $level * @param bool $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct(\AMQPExchange $exchange, $exchangeName = 'log', $level = Logger::DEBUG, $bubble = true) { $this->exchange = $exchange; $this->exchange->setName($exchangeName); parent::__construct($level, $bubble); } /** * {@inheritDoc} */ protected function write(array $record) { $data = $record["formatted"]; $routingKey = sprintf( '%s.%s', substr($record['level_name'], 0, 4), $record['channel'] ); $this->exchange->publish( $data, strtolower($routingKey), 0, array( 'delivery_mode' => 2, 'Content-type' => 'application/json' ) ); } /** * {@inheritDoc} */ protected function getDefaultFormatter() { return new JsonFormatter(); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * Buffers all records until closing the handler and then pass them as batch. * * This is useful for a MailHandler to send only one mail per request instead of * sending one per log message. * * @author Christophe Coevoet */ class BufferHandler extends AbstractHandler { protected $handler; protected $bufferSize = 0; protected $bufferLimit; protected $flushOnOverflow; protected $buffer = array(); /** * @param HandlerInterface $handler Handler. * @param integer $bufferSize How many entries should be buffered at most, beyond that the oldest items are removed from the buffer. * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not * @param Boolean $flushOnOverflow If true, the buffer is flushed when the max size has been reached, by default oldest entries are discarded */ public function __construct(HandlerInterface $handler, $bufferSize = 0, $level = Logger::DEBUG, $bubble = true, $flushOnOverflow = false) { parent::__construct($level, $bubble); $this->handler = $handler; $this->bufferLimit = (int) $bufferSize; $this->flushOnOverflow = $flushOnOverflow; // __destructor() doesn't get called on Fatal errors register_shutdown_function(array($this, 'close')); } /** * {@inheritdoc} */ public function handle(array $record) { if ($record['level'] < $this->level) { return false; } if ($this->bufferLimit > 0 && $this->bufferSize === $this->bufferLimit) { if ($this->flushOnOverflow) { $this->flush(); } else { array_shift($this->buffer); $this->bufferSize--; } } if ($this->processors) { foreach ($this->processors as $processor) { $record = call_user_func($processor, $record); } } $this->buffer[] = $record; $this->bufferSize++; return false === $this->bubble; } public function flush() { if ($this->bufferSize === 0) { return; } $this->handler->handleBatch($this->buffer); $this->bufferSize = 0; $this->buffer = array(); } /** * {@inheritdoc} */ public function close() { $this->flush(); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Formatter\ChromePHPFormatter; /** * Handler sending logs to the ChromePHP extension (http://www.chromephp.com/) * * @author Christophe Coevoet */ class ChromePHPHandler extends AbstractProcessingHandler { /** * Version of the extension */ const VERSION = '3.0'; /** * Header name */ const HEADER_NAME = 'X-ChromePhp-Data'; protected static $initialized = false; protected static $json = array( 'version' => self::VERSION, 'columns' => array('label', 'log', 'backtrace', 'type'), 'rows' => array(), ); protected static $sendHeaders = true; /** * {@inheritdoc} */ public function handleBatch(array $records) { $messages = array(); foreach ($records as $record) { if ($record['level'] < $this->level) { continue; } $messages[] = $this->processRecord($record); } if (!empty($messages)) { $messages = $this->getFormatter()->formatBatch($messages); self::$json['rows'] = array_merge(self::$json['rows'], $messages); $this->send(); } } /** * {@inheritDoc} */ protected function getDefaultFormatter() { return new ChromePHPFormatter(); } /** * Creates & sends header for a record * * @see sendHeader() * @see send() * @param array $record */ protected function write(array $record) { self::$json['rows'][] = $record['formatted']; $this->send(); } /** * Sends the log header * * @see sendHeader() */ protected function send() { if (!self::$initialized) { self::$sendHeaders = $this->headersAccepted(); self::$json['request_uri'] = isset($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : ''; self::$initialized = true; } $json = @json_encode(self::$json); $this->sendHeader(self::HEADER_NAME, base64_encode(utf8_encode($json))); } /** * Send header string to the client * * @param string $header * @param string $content */ protected function sendHeader($header, $content) { if (!headers_sent() && self::$sendHeaders) { header(sprintf('%s: %s', $header, $content)); } } /** * Verifies if the headers are accepted by the current user agent * * @return Boolean */ protected function headersAccepted() { return !isset($_SERVER['HTTP_USER_AGENT']) || preg_match('{\bChrome/\d+[\.\d+]*\b}', $_SERVER['HTTP_USER_AGENT']); } /** * BC getter for the sendHeaders property that has been made static */ public function __get($property) { if ('sendHeaders' !== $property) { throw new \InvalidArgumentException('Undefined property '.$property); } return static::$sendHeaders; } /** * BC setter for the sendHeaders property that has been made static */ public function __set($property, $value) { if ('sendHeaders' !== $property) { throw new \InvalidArgumentException('Undefined property '.$property); } static::$sendHeaders = $value; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Formatter\JsonFormatter; use Monolog\Logger; /** * CouchDB handler * * @author Markus Bachmann */ class CouchDBHandler extends AbstractProcessingHandler { private $options; public function __construct(array $options = array(), $level = Logger::DEBUG, $bubble = true) { $this->options = array_merge(array( 'host' => 'localhost', 'port' => 5984, 'dbname' => 'logger', 'username' => null, 'password' => null, ), $options); parent::__construct($level, $bubble); } /** * {@inheritDoc} */ protected function write(array $record) { $basicAuth = null; if ($this->options['username']) { $basicAuth = sprintf('%s:%s@', $this->options['username'], $this->options['password']); } $url = 'http://'.$basicAuth.$this->options['host'].':'.$this->options['port'].'/'.$this->options['dbname']; $context = stream_context_create(array( 'http' => array( 'method' => 'POST', 'content' => $record['formatted'], 'ignore_errors' => true, 'max_redirects' => 0, 'header' => 'Content-type: application/json', ) )); if (false === @file_get_contents($url, null, $context)) { throw new \RuntimeException(sprintf('Could not connect to %s', $url)); } } /** * {@inheritDoc} */ protected function getDefaultFormatter() { return new JsonFormatter(); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * Logs to Cube. * * @link http://square.github.com/cube/ * @author Wan Chen */ class CubeHandler extends AbstractProcessingHandler { private $udpConnection = null; private $httpConnection = null; private $scheme = null; private $host = null; private $port = null; private $acceptedSchemes = array('http', 'udp'); /** * Create a Cube handler * * @throws UnexpectedValueException when given url is not a valid url. * A valid url must consists of three parts : protocol://host:port * Only valid protocol used by Cube are http and udp */ public function __construct($url, $level = Logger::DEBUG, $bubble = true) { $urlInfos = parse_url($url); if (!isset($urlInfos['scheme']) || !isset($urlInfos['host']) || !isset($urlInfos['port'])) { throw new \UnexpectedValueException('URL "'.$url.'" is not valid'); } if (!in_array($urlInfos['scheme'], $this->acceptedSchemes)) { throw new \UnexpectedValueException( 'Invalid protocol (' . $urlInfos['scheme'] . ').' . ' Valid options are ' . implode(', ', $this->acceptedSchemes)); } $this->scheme = $urlInfos['scheme']; $this->host = $urlInfos['host']; $this->port = $urlInfos['port']; parent::__construct($level, $bubble); } /** * Establish a connection to an UDP socket * * @throws LogicException when unable to connect to the socket */ protected function connectUdp() { if (!extension_loaded('sockets')) { throw new \LogicException('The sockets extension is needed to use udp URLs with the CubeHandler'); } $this->udpConnection = socket_create(AF_INET, SOCK_DGRAM, 0); if (!$this->udpConnection) { throw new \LogicException('Unable to create a socket'); } if (!socket_connect($this->udpConnection, $this->host, $this->port)) { throw new \LogicException('Unable to connect to the socket at ' . $this->host . ':' . $this->port); } } /** * Establish a connection to a http server */ protected function connectHttp() { if (!extension_loaded('curl')) { throw new \LogicException('The curl extension is needed to use http URLs with the CubeHandler'); } $this->httpConnection = curl_init('http://'.$this->host.':'.$this->port.'/1.0/event/put'); if (!$this->httpConnection) { throw new \LogicException('Unable to connect to ' . $this->host . ':' . $this->port); } curl_setopt($this->httpConnection, CURLOPT_CUSTOMREQUEST, "POST"); curl_setopt($this->httpConnection, CURLOPT_RETURNTRANSFER, true); } /** * {@inheritdoc} */ protected function write(array $record) { $date = $record['datetime']; $data = array('time' => $date->format('Y-m-d\TH:i:s.u')); unset($record['datetime']); if (isset($record['context']['type'])) { $data['type'] = $record['context']['type']; unset($record['context']['type']); } else { $data['type'] = $record['channel']; } $data['data'] = $record['context']; $data['data']['level'] = $record['level']; $this->{'write'.$this->scheme}(json_encode($data)); } private function writeUdp($data) { if (!$this->udpConnection) { $this->connectUdp(); } socket_send($this->udpConnection, $data, strlen($data), 0); } private function writeHttp($data) { if (!$this->httpConnection) { $this->connectHttp(); } curl_setopt($this->httpConnection, CURLOPT_POSTFIELDS, '['.$data.']'); curl_setopt($this->httpConnection, CURLOPT_HTTPHEADER, array( 'Content-Type: application/json', 'Content-Length: ' . strlen('['.$data.']')) ); return curl_exec($this->httpConnection); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; use Monolog\Formatter\NormalizerFormatter; use Doctrine\CouchDB\CouchDBClient; /** * CouchDB handler for Doctrine CouchDB ODM * * @author Markus Bachmann */ class DoctrineCouchDBHandler extends AbstractProcessingHandler { private $client; public function __construct(CouchDBClient $client, $level = Logger::DEBUG, $bubble = true) { $this->client = $client; parent::__construct($level, $bubble); } /** * {@inheritDoc} */ protected function write(array $record) { $this->client->postDocument($record['formatted']); } protected function getDefaultFormatter() { return new NormalizerFormatter; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler\FingersCrossed; /** * Interface for activation strategies for the FingersCrossedHandler. * * @author Johannes M. Schmitt */ interface ActivationStrategyInterface { /** * Returns whether the given record activates the handler. * * @param array $record * @return Boolean */ public function isHandlerActivated(array $record); } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler\FingersCrossed; /** * Error level based activation strategy. * * @author Johannes M. Schmitt */ class ErrorLevelActivationStrategy implements ActivationStrategyInterface { private $actionLevel; public function __construct($actionLevel) { $this->actionLevel = $actionLevel; } public function isHandlerActivated(array $record) { return $record['level'] >= $this->actionLevel; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Handler\FingersCrossed\ErrorLevelActivationStrategy; use Monolog\Handler\FingersCrossed\ActivationStrategyInterface; use Monolog\Logger; /** * Buffers all records until a certain level is reached * * The advantage of this approach is that you don't get any clutter in your log files. * Only requests which actually trigger an error (or whatever your actionLevel is) will be * in the logs, but they will contain all records, not only those above the level threshold. * * @author Jordi Boggiano */ class FingersCrossedHandler extends AbstractHandler { protected $handler; protected $activationStrategy; protected $buffering = true; protected $bufferSize; protected $buffer = array(); protected $stopBuffering; /** * @param callable|HandlerInterface $handler Handler or factory callable($record, $fingersCrossedHandler). * @param int|ActivationStrategyInterface $activationStrategy Strategy which determines when this handler takes action * @param int $bufferSize How many entries should be buffered at most, beyond that the oldest items are removed from the buffer. * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not * @param Boolean $stopBuffering Whether the handler should stop buffering after being triggered (default true) */ public function __construct($handler, $activationStrategy = null, $bufferSize = 0, $bubble = true, $stopBuffering = true) { if (null === $activationStrategy) { $activationStrategy = new ErrorLevelActivationStrategy(Logger::WARNING); } if (!$activationStrategy instanceof ActivationStrategyInterface) { $activationStrategy = new ErrorLevelActivationStrategy($activationStrategy); } $this->handler = $handler; $this->activationStrategy = $activationStrategy; $this->bufferSize = $bufferSize; $this->bubble = $bubble; $this->stopBuffering = $stopBuffering; } /** * {@inheritdoc} */ public function isHandling(array $record) { return true; } /** * {@inheritdoc} */ public function handle(array $record) { if ($this->processors) { foreach ($this->processors as $processor) { $record = call_user_func($processor, $record); } } if ($this->buffering) { $this->buffer[] = $record; if ($this->bufferSize > 0 && count($this->buffer) > $this->bufferSize) { array_shift($this->buffer); } if ($this->activationStrategy->isHandlerActivated($record)) { if ($this->stopBuffering) { $this->buffering = false; } if (!$this->handler instanceof HandlerInterface) { if (!is_callable($this->handler)) { throw new \RuntimeException("The given handler (".json_encode($this->handler).") is not a callable nor a Monolog\Handler\HandlerInterface object"); } $this->handler = call_user_func($this->handler, $record, $this); if (!$this->handler instanceof HandlerInterface) { throw new \RuntimeException("The factory callable should return a HandlerInterface"); } } $this->handler->handleBatch($this->buffer); $this->buffer = array(); } } else { $this->handler->handle($record); } return false === $this->bubble; } /** * Resets the state of the handler. Stops forwarding records to the wrapped handler. */ public function reset() { $this->buffering = true; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Formatter\WildfireFormatter; /** * Simple FirePHP Handler (http://www.firephp.org/), which uses the Wildfire protocol. * * @author Eric Clemmons (@ericclemmons) */ class FirePHPHandler extends AbstractProcessingHandler { /** * WildFire JSON header message format */ const PROTOCOL_URI = 'http://meta.wildfirehq.org/Protocol/JsonStream/0.2'; /** * FirePHP structure for parsing messages & their presentation */ const STRUCTURE_URI = 'http://meta.firephp.org/Wildfire/Structure/FirePHP/FirebugConsole/0.1'; /** * Must reference a "known" plugin, otherwise headers won't display in FirePHP */ const PLUGIN_URI = 'http://meta.firephp.org/Wildfire/Plugin/FirePHP/Library-FirePHPCore/0.3'; /** * Header prefix for Wildfire to recognize & parse headers */ const HEADER_PREFIX = 'X-Wf'; /** * Whether or not Wildfire vendor-specific headers have been generated & sent yet */ protected static $initialized = false; /** * Shared static message index between potentially multiple handlers * @var int */ protected static $messageIndex = 1; protected static $sendHeaders = true; /** * Base header creation function used by init headers & record headers * * @param array $meta Wildfire Plugin, Protocol & Structure Indexes * @param string $message Log message * @return array Complete header string ready for the client as key and message as value */ protected function createHeader(array $meta, $message) { $header = sprintf('%s-%s', self::HEADER_PREFIX, join('-', $meta)); return array($header => $message); } /** * Creates message header from record * * @see createHeader() * @param array $record * @return string */ protected function createRecordHeader(array $record) { // Wildfire is extensible to support multiple protocols & plugins in a single request, // but we're not taking advantage of that (yet), so we're using "1" for simplicity's sake. return $this->createHeader( array(1, 1, 1, self::$messageIndex++), $record['formatted'] ); } /** * {@inheritDoc} */ protected function getDefaultFormatter() { return new WildfireFormatter(); } /** * Wildfire initialization headers to enable message parsing * * @see createHeader() * @see sendHeader() * @return array */ protected function getInitHeaders() { // Initial payload consists of required headers for Wildfire return array_merge( $this->createHeader(array('Protocol', 1), self::PROTOCOL_URI), $this->createHeader(array(1, 'Structure', 1), self::STRUCTURE_URI), $this->createHeader(array(1, 'Plugin', 1), self::PLUGIN_URI) ); } /** * Send header string to the client * * @param string $header * @param string $content */ protected function sendHeader($header, $content) { if (!headers_sent() && self::$sendHeaders) { header(sprintf('%s: %s', $header, $content)); } } /** * Creates & sends header for a record, ensuring init headers have been sent prior * * @see sendHeader() * @see sendInitHeaders() * @param array $record */ protected function write(array $record) { // WildFire-specific headers must be sent prior to any messages if (!self::$initialized) { self::$sendHeaders = $this->headersAccepted(); foreach ($this->getInitHeaders() as $header => $content) { $this->sendHeader($header, $content); } self::$initialized = true; } $header = $this->createRecordHeader($record); $this->sendHeader(key($header), current($header)); } /** * Verifies if the headers are accepted by the current user agent * * @return Boolean */ protected function headersAccepted() { return !isset($_SERVER['HTTP_USER_AGENT']) || preg_match('{\bFirePHP/\d+\.\d+\b}', $_SERVER['HTTP_USER_AGENT']) || isset($_SERVER['HTTP_X_FIREPHP_VERSION']); } /** * BC getter for the sendHeaders property that has been made static */ public function __get($property) { if ('sendHeaders' !== $property) { throw new \InvalidArgumentException('Undefined property '.$property); } return static::$sendHeaders; } /** * BC setter for the sendHeaders property that has been made static */ public function __set($property, $value) { if ('sendHeaders' !== $property) { throw new \InvalidArgumentException('Undefined property '.$property); } static::$sendHeaders = $value; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Gelf\IMessagePublisher; use Monolog\Logger; use Monolog\Handler\AbstractProcessingHandler; use Monolog\Formatter\GelfMessageFormatter; /** * Handler to send messages to a Graylog2 (http://www.graylog2.org) server * * @author Matt Lehner */ class GelfHandler extends AbstractProcessingHandler { /** * @var Gelf\IMessagePublisher the publisher object that sends the message to the server */ protected $publisher; /** * @param Gelf\IMessagePublisher $publisher a publisher object * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct(IMessagePublisher $publisher, $level = Logger::DEBUG, $bubble = true) { parent::__construct($level, $bubble); $this->publisher = $publisher; } /** * {@inheritdoc} */ public function close() { $this->publisher = null; } /** * {@inheritdoc} */ protected function write(array $record) { $this->publisher->publish($record['formatted']); } /** * {@inheritDoc} */ protected function getDefaultFormatter() { return new GelfMessageFormatter(); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; /** * Forwards records to multiple handlers * * @author Lenar Lõhmus */ class GroupHandler extends AbstractHandler { protected $handlers; /** * @param array $handlers Array of Handlers. * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct(array $handlers, $bubble = true) { foreach ($handlers as $handler) { if (!$handler instanceof HandlerInterface) { throw new \InvalidArgumentException('The first argument of the GroupHandler must be an array of HandlerInterface instances.'); } } $this->handlers = $handlers; $this->bubble = $bubble; } /** * {@inheritdoc} */ public function isHandling(array $record) { foreach ($this->handlers as $handler) { if ($handler->isHandling($record)) { return true; } } return false; } /** * {@inheritdoc} */ public function handle(array $record) { if ($this->processors) { foreach ($this->processors as $processor) { $record = call_user_func($processor, $record); } } foreach ($this->handlers as $handler) { $handler->handle($record); } return false === $this->bubble; } /** * {@inheritdoc} */ public function handleBatch(array $records) { foreach ($this->handlers as $handler) { $handler->handleBatch($records); } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Formatter\FormatterInterface; /** * Interface that all Monolog Handlers must implement * * @author Jordi Boggiano */ interface HandlerInterface { /** * Checks whether the given record will be handled by this handler. * * This is mostly done for performance reasons, to avoid calling processors for nothing. * * Handlers should still check the record levels within handle(), returning false in isHandling() * is no guarantee that handle() will not be called, and isHandling() might not be called * for a given record. * * @param array $record * * @return Boolean */ public function isHandling(array $record); /** * Handles a record. * * All records may be passed to this method, and the handler should discard * those that it does not want to handle. * * The return value of this function controls the bubbling process of the handler stack. * Unless the bubbling is interrupted (by returning true), the Logger class will keep on * calling further handlers in the stack with a given log record. * * @param array $record The record to handle * @return Boolean True means that this handler handled the record, and that bubbling is not permitted. * False means the record was either not processed or that this handler allows bubbling. */ public function handle(array $record); /** * Handles a set of records at once. * * @param array $records The records to handle (an array of record arrays) */ public function handleBatch(array $records); /** * Adds a processor in the stack. * * @param callable $callback */ public function pushProcessor($callback); /** * Removes the processor on top of the stack and returns it. * * @return callable */ public function popProcessor(); /** * Sets the formatter. * * @param FormatterInterface $formatter */ public function setFormatter(FormatterInterface $formatter); /** * Gets the formatter. * * @return FormatterInterface */ public function getFormatter(); } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; /** * Base class for all mail handlers * * @author Gyula Sallai */ abstract class MailHandler extends AbstractProcessingHandler { /** * {@inheritdoc} */ public function handleBatch(array $records) { $messages = array(); foreach ($records as $record) { if ($record['level'] < $this->level) { continue; } $messages[] = $this->processRecord($record); } if (!empty($messages)) { $this->send((string) $this->getFormatter()->formatBatch($messages), $messages); } } /** * Send a mail with the given content * * @param string $content * @param array $records the array of log records that formed this content */ abstract protected function send($content, array $records); /** * {@inheritdoc} */ protected function write(array $record) { $this->send((string) $record['formatted'], array($record)); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; /** * Exception can be thrown if an extension for an handler is missing * * @author Christian Bergau */ class MissingExtensionException extends \Exception { } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; use Monolog\Formatter\NormalizerFormatter; /** * Logs to a MongoDB database. * * usage example: * * $log = new Logger('application'); * $mongodb = new MongoDBHandler(new \Mongo("mongodb://localhost:27017"), "logs", "prod"); * $log->pushHandler($mongodb); * * @author Thomas Tourlourat */ class MongoDBHandler extends AbstractProcessingHandler { private $mongoCollection; public function __construct($mongo, $database, $collection, $level = Logger::DEBUG, $bubble = true) { if (!($mongo instanceof \MongoClient || $mongo instanceof \Mongo)) { throw new \InvalidArgumentException('MongoClient or Mongo instance required'); } $this->mongoCollection = $mongo->selectCollection($database, $collection); parent::__construct($level, $bubble); } protected function write(array $record) { $this->mongoCollection->save($record["formatted"]); } /** * {@inheritDoc} */ protected function getDefaultFormatter() { return new NormalizerFormatter(); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * NativeMailerHandler uses the mail() function to send the emails * * @author Christophe Coevoet */ class NativeMailerHandler extends MailHandler { protected $to; protected $subject; protected $headers = array( 'Content-type: text/plain; charset=utf-8' ); /** * @param string|array $to The receiver of the mail * @param string $subject The subject of the mail * @param string $from The sender of the mail * @param integer $level The minimum logging level at which this handler will be triggered * @param boolean $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct($to, $subject, $from, $level = Logger::ERROR, $bubble = true) { parent::__construct($level, $bubble); $this->to = is_array($to) ? $to : array($to); $this->subject = $subject; $this->addHeader(sprintf('From: %s', $from)); } /** * @param string|array $headers Custom added headers */ public function addHeader($headers) { foreach ((array) $headers as $header) { if (strpos($header, "\n") !== false || strpos($header, "\r") !== false) { throw new \InvalidArgumentException('Headers can not contain newline characters for security reasons'); } $this->headers[] = $header; } } /** * {@inheritdoc} */ protected function send($content, array $records) { $content = wordwrap($content, 70); $headers = implode("\r\n", $this->headers) . "\r\n"; foreach ($this->to as $to) { mail($to, $this->subject, $content, $headers); } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * Blackhole * * Any record it can handle will be thrown away. This can be used * to put on top of an existing stack to override it temporarily. * * @author Jordi Boggiano */ class NullHandler extends AbstractHandler { /** * @param integer $level The minimum logging level at which this handler will be triggered */ public function __construct($level = Logger::DEBUG) { parent::__construct($level, false); } /** * {@inheritdoc} */ public function handle(array $record) { if ($record['level'] < $this->level) { return false; } return true; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * Sends notifications through the pushover api to mobile phones * * @author Sebastian Göttschkes * @see https://www.pushover.net/api */ class PushoverHandler extends SocketHandler { private $token; private $user; private $title; /** * @param string $token Pushover api token * @param string $user Pushover user id the message will be sent to * @param string $title Title sent to Pushover API * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not * @param Boolean $useSSL Whether to connect via SSL. Required when pushing messages to users that are not * the pushover.net app owner. OpenSSL is required for this option. */ public function __construct($token, $user, $title = null, $level = Logger::CRITICAL, $bubble = true, $useSSL = true) { $connectionString = $useSSL ? 'ssl://api.pushover.net:443' : 'api.pushover.net:80'; parent::__construct($connectionString, $level, $bubble); $this->token = $token; $this->user = $user; $this->title = $title ?: gethostname(); } protected function generateDataStream($record) { $content = $this->buildContent($record); return $this->buildHeader($content) . $content; } private function buildContent($record) { // Pushover has a limit of 512 characters on title and message combined. $maxMessageLength = 512 - strlen($this->title); $message = substr($record['message'], 0, $maxMessageLength); $timestamp = $record['datetime']->getTimestamp(); $dataArray = array( 'token' => $this->token, 'user' => $this->user, 'message' => $message, 'title' => $this->title, 'timestamp' => $timestamp ); return http_build_query($dataArray); } private function buildHeader($content) { $header = "POST /1/messages.json HTTP/1.1\r\n"; $header .= "Host: api.pushover.net\r\n"; $header .= "Content-Type: application/x-www-form-urlencoded\r\n"; $header .= "Content-Length: " . strlen($content) . "\r\n"; $header .= "\r\n"; return $header; } public function write(array $record) { parent::write($record); $this->closeSocket(); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Formatter\LineFormatter; use Monolog\Logger; use Monolog\Handler\AbstractProcessingHandler; use Raven_Client; /** * Handler to send messages to a Sentry (https://github.com/dcramer/sentry) server * using raven-php (https://github.com/getsentry/raven-php) * * @author Marc Abramowitz */ class RavenHandler extends AbstractProcessingHandler { /** * Translates Monolog log levels to Raven log levels. */ private $logLevels = array( Logger::DEBUG => Raven_Client::DEBUG, Logger::INFO => Raven_Client::INFO, Logger::NOTICE => Raven_Client::INFO, Logger::WARNING => Raven_Client::WARNING, Logger::ERROR => Raven_Client::ERROR, Logger::CRITICAL => Raven_Client::FATAL, Logger::ALERT => Raven_Client::FATAL, Logger::EMERGENCY => Raven_Client::FATAL, ); /** * @var Raven_Client the client object that sends the message to the server */ protected $ravenClient; /** * @param Raven_Client $ravenClient * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct(Raven_Client $ravenClient, $level = Logger::DEBUG, $bubble = true) { parent::__construct($level, $bubble); $this->ravenClient = $ravenClient; } /** * {@inheritdoc} */ protected function write(array $record) { $level = $this->logLevels[$record['level']]; $options = array(); $options['level'] = $level; if (!empty($record['context'])) { $options['extra']['context'] = $record['context']; } if (!empty($record['extra'])) { $options['extra']['extra'] = $record['extra']; } $this->ravenClient->captureMessage( $record['formatted'], array(), // $params - not used version_compare(Raven_Client::VERSION, '0.1.0', '>') ? $options : $level, // $level or $options false // $stack ); if ($record['level'] >= Logger::ERROR && isset($record['context']['exception'])) { $this->ravenClient->captureException($record['context']['exception']); } } /** * {@inheritDoc} */ protected function getDefaultFormatter() { return new LineFormatter('[%channel%] %message%'); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; use Monolog\Formatter\LineFormatter; /** * Logs to a Redis key using rpush * * usage example: * * $log = new Logger('application'); * $redis = new RedisHandler(new Predis\Client("tcp://localhost:6379"), "logs", "prod"); * $log->pushHandler($redis); * * @author Thomas Tourlourat */ class RedisHandler extends AbstractProcessingHandler { private $redisClient; private $redisKey; # redis instance, key to use public function __construct($redis, $key, $level = Logger::DEBUG, $bubble = true) { if (!(($redis instanceof \Predis\Client) || ($redis instanceof \Redis))) { throw new \InvalidArgumentException('Predis\Client or Redis instance required'); } $this->redisClient = $redis; $this->redisKey = $key; parent::__construct($level, $bubble); } protected function write(array $record) { $this->redisClient->rpush($this->redisKey, $record["formatted"]); } /** * {@inheritDoc} */ protected function getDefaultFormatter() { return new LineFormatter(); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * Stores logs to files that are rotated every day and a limited number of files are kept. * * This rotation is only intended to be used as a workaround. Using logrotate to * handle the rotation is strongly encouraged when you can use it. * * @author Christophe Coevoet * @author Jordi Boggiano */ class RotatingFileHandler extends StreamHandler { protected $filename; protected $maxFiles; protected $mustRotate; protected $nextRotation; /** * @param string $filename * @param integer $maxFiles The maximal amount of files to keep (0 means unlimited) * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct($filename, $maxFiles = 0, $level = Logger::DEBUG, $bubble = true) { $this->filename = $filename; $this->maxFiles = (int) $maxFiles; $this->nextRotation = new \DateTime('tomorrow'); parent::__construct($this->getTimedFilename(), $level, $bubble); } /** * {@inheritdoc} */ public function close() { parent::close(); if (true === $this->mustRotate) { $this->rotate(); } } /** * {@inheritdoc} */ protected function write(array $record) { // on the first record written, if the log is new, we should rotate (once per day) if (null === $this->mustRotate) { $this->mustRotate = !file_exists($this->url); } if ($this->nextRotation < $record['datetime']) { $this->mustRotate = true; $this->close(); } parent::write($record); } /** * Rotates the files. */ protected function rotate() { // update filename $this->url = $this->getTimedFilename(); $this->nextRotation = new \DateTime('tomorrow'); // skip GC of old logs if files are unlimited if (0 === $this->maxFiles) { return; } $fileInfo = pathinfo($this->filename); $glob = $fileInfo['dirname'].'/'.$fileInfo['filename'].'-*'; if (!empty($fileInfo['extension'])) { $glob .= '.'.$fileInfo['extension']; } $iterator = new \GlobIterator($glob); $count = $iterator->count(); if ($this->maxFiles >= $count) { // no files to remove return; } // Sorting the files by name to remove the older ones $array = iterator_to_array($iterator); usort($array, function($a, $b) { return strcmp($b->getFilename(), $a->getFilename()); }); foreach (array_slice($array, $this->maxFiles) as $file) { if ($file->isWritable()) { unlink($file->getRealPath()); } } } protected function getTimedFilename() { $fileInfo = pathinfo($this->filename); $timedFilename = $fileInfo['dirname'].'/'.$fileInfo['filename'].'-'.date('Y-m-d'); if (!empty($fileInfo['extension'])) { $timedFilename .= '.'.$fileInfo['extension']; } return $timedFilename; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * Stores to any socket - uses fsockopen() or pfsockopen(). * * @author Pablo de Leon Belloc * @see http://php.net/manual/en/function.fsockopen.php */ class SocketHandler extends AbstractProcessingHandler { private $connectionString; private $connectionTimeout; private $resource; private $timeout = 0; private $persistent = false; private $errno; private $errstr; /** * @param string $connectionString Socket connection string * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct($connectionString, $level = Logger::DEBUG, $bubble = true) { parent::__construct($level, $bubble); $this->connectionString = $connectionString; $this->connectionTimeout = (float) ini_get('default_socket_timeout'); } /** * Connect (if necessary) and write to the socket * * @param array $record * * @throws \UnexpectedValueException * @throws \RuntimeException */ public function write(array $record) { $this->connectIfNotConnected(); $data = $this->generateDataStream($record); $this->writeToSocket($data); } /** * We will not close a PersistentSocket instance so it can be reused in other requests. */ public function close() { if (!$this->isPersistent()) { $this->closeSocket(); } } /** * Close socket, if open */ public function closeSocket() { if (is_resource($this->resource)) { fclose($this->resource); $this->resource = null; } } /** * Set socket connection to nbe persistent. It only has effect before the connection is initiated. * * @param type $boolean */ public function setPersistent($boolean) { $this->persistent = (boolean) $boolean; } /** * Set connection timeout. Only has effect before we connect. * * @param float $seconds * * @see http://php.net/manual/en/function.fsockopen.php */ public function setConnectionTimeout($seconds) { $this->validateTimeout($seconds); $this->connectionTimeout = (float) $seconds; } /** * Set write timeout. Only has effect before we connect. * * @param float $seconds * * @see http://php.net/manual/en/function.stream-set-timeout.php */ public function setTimeout($seconds) { $this->validateTimeout($seconds); $this->timeout = (float) $seconds; } /** * Get current connection string * * @return string */ public function getConnectionString() { return $this->connectionString; } /** * Get persistent setting * * @return boolean */ public function isPersistent() { return $this->persistent; } /** * Get current connection timeout setting * * @return float */ public function getConnectionTimeout() { return $this->connectionTimeout; } /** * Get current in-transfer timeout * * @return float */ public function getTimeout() { return $this->timeout; } /** * Check to see if the socket is currently available. * * UDP might appear to be connected but might fail when writing. See http://php.net/fsockopen for details. * * @return boolean */ public function isConnected() { return is_resource($this->resource) && !feof($this->resource); // on TCP - other party can close connection. } /** * Wrapper to allow mocking */ protected function pfsockopen() { return @pfsockopen($this->connectionString, -1, $this->errno, $this->errstr, $this->connectionTimeout); } /** * Wrapper to allow mocking */ protected function fsockopen() { return @fsockopen($this->connectionString, -1, $this->errno, $this->errstr, $this->connectionTimeout); } /** * Wrapper to allow mocking * * @see http://php.net/manual/en/function.stream-set-timeout.php */ protected function streamSetTimeout() { $seconds = floor($this->timeout); $microseconds = round(($this->timeout - $seconds)*1e6); return stream_set_timeout($this->resource, $seconds, $microseconds); } /** * Wrapper to allow mocking */ protected function fwrite($data) { return @fwrite($this->resource, $data); } /** * Wrapper to allow mocking */ protected function streamGetMetadata() { return stream_get_meta_data($this->resource); } private function validateTimeout($value) { $ok = filter_var($value, FILTER_VALIDATE_FLOAT); if ($ok === false || $value < 0) { throw new \InvalidArgumentException("Timeout must be 0 or a positive float (got $value)"); } } private function connectIfNotConnected() { if ($this->isConnected()) { return; } $this->connect(); } protected function generateDataStream($record) { return (string) $record['formatted']; } private function connect() { $this->createSocketResource(); $this->setSocketTimeout(); } private function createSocketResource() { if ($this->isPersistent()) { $resource = $this->pfsockopen(); } else { $resource = $this->fsockopen(); } if (!$resource) { throw new \UnexpectedValueException("Failed connecting to $this->connectionString ($this->errno: $this->errstr)"); } $this->resource = $resource; } private function setSocketTimeout() { if (!$this->streamSetTimeout()) { throw new \UnexpectedValueException("Failed setting timeout with stream_set_timeout()"); } } private function writeToSocket($data) { $length = strlen($data); $sent = 0; while ($this->isConnected() && $sent < $length) { if (0 == $sent) { $chunk = $this->fwrite($data); } else { $chunk = $this->fwrite(substr($data, $sent)); } if ($chunk === false) { throw new \RuntimeException("Could not write to socket"); } $sent += $chunk; $socketInfo = $this->streamGetMetadata(); if ($socketInfo['timed_out']) { throw new \RuntimeException("Write timed-out"); } } if (!$this->isConnected() && $sent < $length) { throw new \RuntimeException("End-of-file reached, probably we got disconnected (sent $sent of $length)"); } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * Stores to any stream resource * * Can be used to store into php://stderr, remote and local files, etc. * * @author Jordi Boggiano */ class StreamHandler extends AbstractProcessingHandler { protected $stream; protected $url; /** * @param string $stream * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct($stream, $level = Logger::DEBUG, $bubble = true) { parent::__construct($level, $bubble); if (is_resource($stream)) { $this->stream = $stream; } else { $this->url = $stream; } } /** * {@inheritdoc} */ public function close() { if (is_resource($this->stream)) { fclose($this->stream); } $this->stream = null; } /** * {@inheritdoc} */ protected function write(array $record) { if (null === $this->stream) { if (!$this->url) { throw new \LogicException('Missing stream url, the stream can not be opened. This may be caused by a premature call to close().'); } $errorMessage = null; set_error_handler(function ($code, $msg) use (&$errorMessage) { $errorMessage = preg_replace('{^fopen\(.*?\): }', '', $msg); }); $this->stream = fopen($this->url, 'a'); restore_error_handler(); if (!is_resource($this->stream)) { $this->stream = null; throw new \UnexpectedValueException(sprintf('The stream or file "%s" could not be opened: '.$errorMessage, $this->url)); } } fwrite($this->stream, (string) $record['formatted']); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * SwiftMailerHandler uses Swift_Mailer to send the emails * * @author Gyula Sallai */ class SwiftMailerHandler extends MailHandler { protected $mailer; protected $message; /** * @param \Swift_Mailer $mailer The mailer to use * @param callable|\Swift_Message $message An example message for real messages, only the body will be replaced * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not */ public function __construct(\Swift_Mailer $mailer, $message, $level = Logger::ERROR, $bubble = true) { parent::__construct($level, $bubble); $this->mailer = $mailer; if (!$message instanceof \Swift_Message && is_callable($message)) { $message = call_user_func($message); } if (!$message instanceof \Swift_Message) { throw new \InvalidArgumentException('You must provide either a Swift_Message instance or a callable returning it'); } $this->message = $message; } /** * {@inheritdoc} */ protected function send($content, array $records) { $message = clone $this->message; $message->setBody($content); $this->mailer->send($message); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; use Monolog\Formatter\LineFormatter; /** * Logs to syslog service. * * usage example: * * $log = new Logger('application'); * $syslog = new SyslogHandler('myfacility', 'local6'); * $formatter = new LineFormatter("%channel%.%level_name%: %message% %extra%"); * $syslog->setFormatter($formatter); * $log->pushHandler($syslog); * * @author Sven Paulus */ class SyslogHandler extends AbstractProcessingHandler { /** * Translates Monolog log levels to syslog log priorities. */ private $logLevels = array( Logger::DEBUG => LOG_DEBUG, Logger::INFO => LOG_INFO, Logger::NOTICE => LOG_NOTICE, Logger::WARNING => LOG_WARNING, Logger::ERROR => LOG_ERR, Logger::CRITICAL => LOG_CRIT, Logger::ALERT => LOG_ALERT, Logger::EMERGENCY => LOG_EMERG, ); /** * List of valid log facility names. */ private $facilities = array( 'auth' => LOG_AUTH, 'authpriv' => LOG_AUTHPRIV, 'cron' => LOG_CRON, 'daemon' => LOG_DAEMON, 'kern' => LOG_KERN, 'lpr' => LOG_LPR, 'mail' => LOG_MAIL, 'news' => LOG_NEWS, 'syslog' => LOG_SYSLOG, 'user' => LOG_USER, 'uucp' => LOG_UUCP, ); /** * @param string $ident * @param mixed $facility * @param integer $level The minimum logging level at which this handler will be triggered * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not * @param int $logopts Option flags for the openlog() call, defaults to LOG_PID */ public function __construct($ident, $facility = LOG_USER, $level = Logger::DEBUG, $bubble = true, $logopts = LOG_PID) { parent::__construct($level, $bubble); if (!defined('PHP_WINDOWS_VERSION_BUILD')) { $this->facilities['local0'] = LOG_LOCAL0; $this->facilities['local1'] = LOG_LOCAL1; $this->facilities['local2'] = LOG_LOCAL2; $this->facilities['local3'] = LOG_LOCAL3; $this->facilities['local4'] = LOG_LOCAL4; $this->facilities['local5'] = LOG_LOCAL5; $this->facilities['local6'] = LOG_LOCAL6; $this->facilities['local7'] = LOG_LOCAL7; } // convert textual description of facility to syslog constant if (array_key_exists(strtolower($facility), $this->facilities)) { $facility = $this->facilities[strtolower($facility)]; } elseif (!in_array($facility, array_values($this->facilities), true)) { throw new \UnexpectedValueException('Unknown facility value "'.$facility.'" given'); } if (!openlog($ident, $logopts, $facility)) { throw new \LogicException('Can\'t open syslog for ident "'.$ident.'" and facility "'.$facility.'"'); } } /** * {@inheritdoc} */ public function close() { closelog(); } /** * {@inheritdoc} */ protected function write(array $record) { syslog($this->logLevels[$record['level']], (string) $record['formatted']); } /** * {@inheritdoc} */ protected function getDefaultFormatter() { return new LineFormatter('%channel%.%level_name%: %message% %context% %extra%'); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Logger; /** * Used for testing purposes. * * It records all records and gives you access to them for verification. * * @author Jordi Boggiano */ class TestHandler extends AbstractProcessingHandler { protected $records = array(); protected $recordsByLevel = array(); public function getRecords() { return $this->records; } public function hasEmergency($record) { return $this->hasRecord($record, Logger::EMERGENCY); } public function hasAlert($record) { return $this->hasRecord($record, Logger::ALERT); } public function hasCritical($record) { return $this->hasRecord($record, Logger::CRITICAL); } public function hasError($record) { return $this->hasRecord($record, Logger::ERROR); } public function hasWarning($record) { return $this->hasRecord($record, Logger::WARNING); } public function hasNotice($record) { return $this->hasRecord($record, Logger::NOTICE); } public function hasInfo($record) { return $this->hasRecord($record, Logger::INFO); } public function hasDebug($record) { return $this->hasRecord($record, Logger::DEBUG); } public function hasEmergencyRecords() { return isset($this->recordsByLevel[Logger::EMERGENCY]); } public function hasAlertRecords() { return isset($this->recordsByLevel[Logger::ALERT]); } public function hasCriticalRecords() { return isset($this->recordsByLevel[Logger::CRITICAL]); } public function hasErrorRecords() { return isset($this->recordsByLevel[Logger::ERROR]); } public function hasWarningRecords() { return isset($this->recordsByLevel[Logger::WARNING]); } public function hasNoticeRecords() { return isset($this->recordsByLevel[Logger::NOTICE]); } public function hasInfoRecords() { return isset($this->recordsByLevel[Logger::INFO]); } public function hasDebugRecords() { return isset($this->recordsByLevel[Logger::DEBUG]); } protected function hasRecord($record, $level) { if (!isset($this->recordsByLevel[$level])) { return false; } if (is_array($record)) { $record = $record['message']; } foreach ($this->recordsByLevel[$level] as $rec) { if ($rec['message'] === $record) { return true; } } return false; } /** * {@inheritdoc} */ protected function write(array $record) { $this->recordsByLevel[$record['level']][] = $record; $this->records[] = $record; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Handler; use Monolog\Formatter\NormalizerFormatter; use Monolog\Logger; /** * Handler sending logs to Zend Monitor * * @author Christian Bergau */ class ZendMonitorHandler extends AbstractProcessingHandler { /** * Monolog level / ZendMonitor Custom Event priority map * * @var array */ protected $levelMap = array( Logger::DEBUG => 1, Logger::INFO => 2, Logger::NOTICE => 3, Logger::WARNING => 4, Logger::ERROR => 5, Logger::CRITICAL => 6, Logger::ALERT => 7, Logger::EMERGENCY => 0, ); /** * Construct * * @param int $level * @param bool $bubble * @throws MissingExtensionException */ public function __construct($level = Logger::DEBUG, $bubble = true) { if (!function_exists('zend_monitor_custom_event')) { throw new MissingExtensionException('You must have Zend Server installed in order to use this handler'); } parent::__construct($level, $bubble); } /** * {@inheritdoc} */ protected function write(array $record) { $this->writeZendMonitorCustomEvent( $this->levelMap[$record['level']], $record['message'], $record['formatted'] ); } /** * Write a record to Zend Monitor * * @param int $level * @param string $message * @param array $formatted */ protected function writeZendMonitorCustomEvent($level, $message, $formatted) { zend_monitor_custom_event($level, $message, $formatted); } /** * {@inheritdoc} */ public function getDefaultFormatter() { return new NormalizerFormatter(); } /** * Get the level map * * @return array */ public function getLevelMap() { return $this->levelMap; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog; use Monolog\Handler\HandlerInterface; use Monolog\Handler\StreamHandler; use Psr\Log\LoggerInterface; use Psr\Log\InvalidArgumentException; /** * Monolog log channel * * It contains a stack of Handlers and a stack of Processors, * and uses them to store records that are added to it. * * @author Jordi Boggiano */ class Logger implements LoggerInterface { /** * Detailed debug information */ const DEBUG = 100; /** * Interesting events * * Examples: User logs in, SQL logs. */ const INFO = 200; /** * Uncommon events */ const NOTICE = 250; /** * Exceptional occurrences that are not errors * * Examples: Use of deprecated APIs, poor use of an API, * undesirable things that are not necessarily wrong. */ const WARNING = 300; /** * Runtime errors */ const ERROR = 400; /** * Critical conditions * * Example: Application component unavailable, unexpected exception. */ const CRITICAL = 500; /** * Action must be taken immediately * * Example: Entire website down, database unavailable, etc. * This should trigger the SMS alerts and wake you up. */ const ALERT = 550; /** * Urgent alert. */ const EMERGENCY = 600; protected static $levels = array( 100 => 'DEBUG', 200 => 'INFO', 250 => 'NOTICE', 300 => 'WARNING', 400 => 'ERROR', 500 => 'CRITICAL', 550 => 'ALERT', 600 => 'EMERGENCY', ); /** * @var DateTimeZone */ protected static $timezone; protected $name; /** * The handler stack * * @var array of Monolog\Handler\HandlerInterface */ protected $handlers; /** * Processors that will process all log records * * To process records of a single handler instead, add the processor on that specific handler * * @var array of callables */ protected $processors; /** * @param string $name The logging channel * @param array $handlers Optional stack of handlers, the first one in the array is called first, etc. * @param array $processors Optional array of processors */ public function __construct($name, array $handlers = array(), array $processors = array()) { $this->name = $name; $this->handlers = $handlers; $this->processors = $processors; } /** * @return string */ public function getName() { return $this->name; } /** * Pushes a handler on to the stack. * * @param HandlerInterface $handler */ public function pushHandler(HandlerInterface $handler) { array_unshift($this->handlers, $handler); } /** * Pops a handler from the stack * * @return HandlerInterface */ public function popHandler() { if (!$this->handlers) { throw new \LogicException('You tried to pop from an empty handler stack.'); } return array_shift($this->handlers); } /** * Adds a processor on to the stack. * * @param callable $callback */ public function pushProcessor($callback) { if (!is_callable($callback)) { throw new \InvalidArgumentException('Processors must be valid callables (callback or object with an __invoke method), '.var_export($callback, true).' given'); } array_unshift($this->processors, $callback); } /** * Removes the processor on top of the stack and returns it. * * @return callable */ public function popProcessor() { if (!$this->processors) { throw new \LogicException('You tried to pop from an empty processor stack.'); } return array_shift($this->processors); } /** * Adds a log record. * * @param integer $level The logging level * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function addRecord($level, $message, array $context = array()) { if (!$this->handlers) { $this->pushHandler(new StreamHandler('php://stderr', static::DEBUG)); } if (!static::$timezone) { static::$timezone = new \DateTimeZone(date_default_timezone_get() ?: 'UTC'); } $record = array( 'message' => (string) $message, 'context' => $context, 'level' => $level, 'level_name' => static::getLevelName($level), 'channel' => $this->name, 'datetime' => \DateTime::createFromFormat('U.u', sprintf('%.6F', microtime(true)), static::$timezone)->setTimezone(static::$timezone), 'extra' => array(), ); // check if any handler will handle this message $handlerKey = null; foreach ($this->handlers as $key => $handler) { if ($handler->isHandling($record)) { $handlerKey = $key; break; } } // none found if (null === $handlerKey) { return false; } // found at least one, process message and dispatch it foreach ($this->processors as $processor) { $record = call_user_func($processor, $record); } while (isset($this->handlers[$handlerKey]) && false === $this->handlers[$handlerKey]->handle($record)) { $handlerKey++; } return true; } /** * Adds a log record at the DEBUG level. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function addDebug($message, array $context = array()) { return $this->addRecord(static::DEBUG, $message, $context); } /** * Adds a log record at the INFO level. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function addInfo($message, array $context = array()) { return $this->addRecord(static::INFO, $message, $context); } /** * Adds a log record at the NOTICE level. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function addNotice($message, array $context = array()) { return $this->addRecord(static::NOTICE, $message, $context); } /** * Adds a log record at the WARNING level. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function addWarning($message, array $context = array()) { return $this->addRecord(static::WARNING, $message, $context); } /** * Adds a log record at the ERROR level. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function addError($message, array $context = array()) { return $this->addRecord(static::ERROR, $message, $context); } /** * Adds a log record at the CRITICAL level. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function addCritical($message, array $context = array()) { return $this->addRecord(static::CRITICAL, $message, $context); } /** * Adds a log record at the ALERT level. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function addAlert($message, array $context = array()) { return $this->addRecord(static::ALERT, $message, $context); } /** * Adds a log record at the EMERGENCY level. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function addEmergency($message, array $context = array()) { return $this->addRecord(static::EMERGENCY, $message, $context); } /** * Gets the name of the logging level. * * @param integer $level * @return string */ public static function getLevelName($level) { if (!isset(static::$levels[$level])) { throw new InvalidArgumentException('Level "'.$level.'" is not defined, use one of: '.implode(', ', array_keys(static::$levels))); } return static::$levels[$level]; } /** * Checks whether the Logger has a handler that listens on the given level * * @param integer $level * @return Boolean */ public function isHandling($level) { $record = array( 'level' => $level, ); foreach ($this->handlers as $key => $handler) { if ($handler->isHandling($record)) { return true; } } return false; } /** * Adds a log record at an arbitrary level. * * This method allows for compatibility with common interfaces. * * @param mixed $level The log level * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function log($level, $message, array $context = array()) { if (is_string($level) && defined(__CLASS__.'::'.strtoupper($level))) { $level = constant(__CLASS__.'::'.strtoupper($level)); } return $this->addRecord($level, $message, $context); } /** * Adds a log record at the DEBUG level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function debug($message, array $context = array()) { return $this->addRecord(static::DEBUG, $message, $context); } /** * Adds a log record at the INFO level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function info($message, array $context = array()) { return $this->addRecord(static::INFO, $message, $context); } /** * Adds a log record at the INFO level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function notice($message, array $context = array()) { return $this->addRecord(static::NOTICE, $message, $context); } /** * Adds a log record at the WARNING level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function warn($message, array $context = array()) { return $this->addRecord(static::WARNING, $message, $context); } /** * Adds a log record at the WARNING level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function warning($message, array $context = array()) { return $this->addRecord(static::WARNING, $message, $context); } /** * Adds a log record at the ERROR level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function err($message, array $context = array()) { return $this->addRecord(static::ERROR, $message, $context); } /** * Adds a log record at the ERROR level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function error($message, array $context = array()) { return $this->addRecord(static::ERROR, $message, $context); } /** * Adds a log record at the CRITICAL level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function crit($message, array $context = array()) { return $this->addRecord(static::CRITICAL, $message, $context); } /** * Adds a log record at the CRITICAL level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function critical($message, array $context = array()) { return $this->addRecord(static::CRITICAL, $message, $context); } /** * Adds a log record at the ALERT level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function alert($message, array $context = array()) { return $this->addRecord(static::ALERT, $message, $context); } /** * Adds a log record at the EMERGENCY level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function emerg($message, array $context = array()) { return $this->addRecord(static::EMERGENCY, $message, $context); } /** * Adds a log record at the EMERGENCY level. * * This method allows for compatibility with common interfaces. * * @param string $message The log message * @param array $context The log context * @return Boolean Whether the record has been processed */ public function emergency($message, array $context = array()) { return $this->addRecord(static::EMERGENCY, $message, $context); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Processor; /** * Injects line/file:class/function where the log message came from * * Warning: This only works if the handler processes the logs directly. * If you put the processor on a handler that is behind a FingersCrossedHandler * for example, the processor will only be called once the trigger level is reached, * and all the log records will have the same file/line/.. data from the call that * triggered the FingersCrossedHandler. * * @author Jordi Boggiano */ class IntrospectionProcessor { /** * @param array $record * @return array */ public function __invoke(array $record) { $trace = debug_backtrace(); // skip first since it's always the current method array_shift($trace); // the call_user_func call is also skipped array_shift($trace); $i = 0; while (isset($trace[$i]['class']) && false !== strpos($trace[$i]['class'], 'Monolog\\')) { $i++; } // we should have the call source now $record['extra'] = array_merge( $record['extra'], array( 'file' => isset($trace[$i-1]['file']) ? $trace[$i-1]['file'] : null, 'line' => isset($trace[$i-1]['line']) ? $trace[$i-1]['line'] : null, 'class' => isset($trace[$i]['class']) ? $trace[$i]['class'] : null, 'function' => isset($trace[$i]['function']) ? $trace[$i]['function'] : null, ) ); return $record; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Processor; /** * Injects memory_get_peak_usage in all records * * @see Monolog\Processor\MemoryProcessor::__construct() for options * @author Rob Jensen */ class MemoryPeakUsageProcessor extends MemoryProcessor { /** * @param array $record * @return array */ public function __invoke(array $record) { $bytes = memory_get_peak_usage($this->realUsage); $formatted = self::formatBytes($bytes); $record['extra'] = array_merge( $record['extra'], array( 'memory_peak_usage' => $formatted, ) ); return $record; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Processor; /** * Some methods that are common for all memory processors * * @author Rob Jensen */ abstract class MemoryProcessor { protected $realUsage; /** * @param boolean $realUsage */ public function __construct($realUsage = true) { $this->realUsage = (boolean) $realUsage; } /** * Formats bytes into a human readable string * * @param int $bytes * @return string */ protected static function formatBytes($bytes) { $bytes = (int) $bytes; if ($bytes > 1024*1024) { return round($bytes/1024/1024, 2).' MB'; } elseif ($bytes > 1024) { return round($bytes/1024, 2).' KB'; } return $bytes . ' B'; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Processor; /** * Injects memory_get_usage in all records * * @see Monolog\Processor\MemoryProcessor::__construct() for options * @author Rob Jensen */ class MemoryUsageProcessor extends MemoryProcessor { /** * @param array $record * @return array */ public function __invoke(array $record) { $bytes = memory_get_usage($this->realUsage); $formatted = self::formatBytes($bytes); $record['extra'] = array_merge( $record['extra'], array( 'memory_usage' => $formatted, ) ); return $record; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Processor; /** * Processes a record's message according to PSR-3 rules * * It replaces {foo} with the value from $context['foo'] * * @author Jordi Boggiano */ class PsrLogMessageProcessor { /** * @param array $record * @return array */ public function __invoke(array $record) { if (false === strpos($record['message'], '{')) { return $record; } $replacements = array(); foreach ($record['context'] as $key => $val) { $replacements['{'.$key.'}'] = $val; } $record['message'] = strtr($record['message'], $replacements); return $record; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Monolog\Processor; /** * Injects url/method and remote IP of the current web request in all records * * @author Jordi Boggiano */ class WebProcessor { protected $serverData; /** * @param mixed $serverData array or object w/ ArrayAccess that provides access to the $_SERVER data */ public function __construct($serverData = null) { if (null === $serverData) { $this->serverData =& $_SERVER; } elseif (is_array($serverData) || $serverData instanceof \ArrayAccess) { $this->serverData = $serverData; } else { throw new \UnexpectedValueException('$serverData must be an array or object implementing ArrayAccess.'); } } /** * @param array $record * @return array */ public function __invoke(array $record) { // skip processing if for some reason request data // is not present (CLI or wonky SAPIs) if (!isset($this->serverData['REQUEST_URI'])) { return $record; } $record['extra'] = array_merge( $record['extra'], array( 'url' => $this->serverData['REQUEST_URI'], 'ip' => isset($this->serverData['REMOTE_ADDR']) ? $this->serverData['REMOTE_ADDR'] : null, 'http_method' => isset($this->serverData['REQUEST_METHOD']) ? $this->serverData['REQUEST_METHOD'] : null, 'server' => isset($this->serverData['SERVER_NAME']) ? $this->serverData['SERVER_NAME'] : null, 'referrer' => isset($this->serverData['HTTP_REFERER']) ? $this->serverData['HTTP_REFERER'] : null, ) ); return $record; } } log(LogLevel::EMERGENCY, $message, $context); } /** * Action must be taken immediately. * * Example: Entire website down, database unavailable, etc. This should * trigger the SMS alerts and wake you up. * * @param string $message * @param array $context * @return null */ public function alert($message, array $context = array()) { $this->log(LogLevel::ALERT, $message, $context); } /** * Critical conditions. * * Example: Application component unavailable, unexpected exception. * * @param string $message * @param array $context * @return null */ public function critical($message, array $context = array()) { $this->log(LogLevel::CRITICAL, $message, $context); } /** * Runtime errors that do not require immediate action but should typically * be logged and monitored. * * @param string $message * @param array $context * @return null */ public function error($message, array $context = array()) { $this->log(LogLevel::ERROR, $message, $context); } /** * Exceptional occurrences that are not errors. * * Example: Use of deprecated APIs, poor use of an API, undesirable things * that are not necessarily wrong. * * @param string $message * @param array $context * @return null */ public function warning($message, array $context = array()) { $this->log(LogLevel::WARNING, $message, $context); } /** * Normal but significant events. * * @param string $message * @param array $context * @return null */ public function notice($message, array $context = array()) { $this->log(LogLevel::NOTICE, $message, $context); } /** * Interesting events. * * Example: User logs in, SQL logs. * * @param string $message * @param array $context * @return null */ public function info($message, array $context = array()) { $this->log(LogLevel::INFO, $message, $context); } /** * Detailed debug information. * * @param string $message * @param array $context * @return null */ public function debug($message, array $context = array()) { $this->log(LogLevel::DEBUG, $message, $context); } } logger = $logger; } } log(LogLevel::EMERGENCY, $message, $context); } /** * Action must be taken immediately. * * Example: Entire website down, database unavailable, etc. This should * trigger the SMS alerts and wake you up. * * @param string $message * @param array $context * @return null */ public function alert($message, array $context = array()) { $this->log(LogLevel::ALERT, $message, $context); } /** * Critical conditions. * * Example: Application component unavailable, unexpected exception. * * @param string $message * @param array $context * @return null */ public function critical($message, array $context = array()) { $this->log(LogLevel::CRITICAL, $message, $context); } /** * Runtime errors that do not require immediate action but should typically * be logged and monitored. * * @param string $message * @param array $context * @return null */ public function error($message, array $context = array()) { $this->log(LogLevel::ERROR, $message, $context); } /** * Exceptional occurrences that are not errors. * * Example: Use of deprecated APIs, poor use of an API, undesirable things * that are not necessarily wrong. * * @param string $message * @param array $context * @return null */ public function warning($message, array $context = array()) { $this->log(LogLevel::WARNING, $message, $context); } /** * Normal but significant events. * * @param string $message * @param array $context * @return null */ public function notice($message, array $context = array()) { $this->log(LogLevel::NOTICE, $message, $context); } /** * Interesting events. * * Example: User logs in, SQL logs. * * @param string $message * @param array $context * @return null */ public function info($message, array $context = array()) { $this->log(LogLevel::INFO, $message, $context); } /** * Detailed debug information. * * @param string $message * @param array $context * @return null */ public function debug($message, array $context = array()) { $this->log(LogLevel::DEBUG, $message, $context); } /** * Logs with an arbitrary level. * * @param mixed $level * @param string $message * @param array $context * @return null */ abstract public function log($level, $message, array $context = array()); } logger) { }` * blocks. */ class NullLogger extends AbstractLogger { /** * Logs with an arbitrary level. * * @param mixed $level * @param string $message * @param array $context * @return null */ public function log($level, $message, array $context = array()) { // noop } } " * * Example ->error('Foo') would yield "error Foo" * * @return string[] */ abstract function getLogs(); public function testImplements() { $this->assertInstanceOf('Psr\Log\LoggerInterface', $this->getLogger()); } /** * @dataProvider provideLevelsAndMessages */ public function testLogsAtAllLevels($level, $message) { $logger = $this->getLogger(); $logger->{$level}($message, array('user' => 'Bob')); $logger->log($level, $message, array('user' => 'Bob')); $expected = array( $level.' message of level '.$level.' with context: Bob', $level.' message of level '.$level.' with context: Bob', ); $this->assertEquals($expected, $this->getLogs()); } public function provideLevelsAndMessages() { return array( LogLevel::EMERGENCY => array(LogLevel::EMERGENCY, 'message of level emergency with context: {user}'), LogLevel::ALERT => array(LogLevel::ALERT, 'message of level alert with context: {user}'), LogLevel::CRITICAL => array(LogLevel::CRITICAL, 'message of level critical with context: {user}'), LogLevel::ERROR => array(LogLevel::ERROR, 'message of level error with context: {user}'), LogLevel::WARNING => array(LogLevel::WARNING, 'message of level warning with context: {user}'), LogLevel::NOTICE => array(LogLevel::NOTICE, 'message of level notice with context: {user}'), LogLevel::INFO => array(LogLevel::INFO, 'message of level info with context: {user}'), LogLevel::DEBUG => array(LogLevel::DEBUG, 'message of level debug with context: {user}'), ); } /** * @expectedException Psr\Log\InvalidArgumentException */ public function testThrowsOnInvalidLevel() { $logger = $this->getLogger(); $logger->log('invalid level', 'Foo'); } public function testContextReplacement() { $logger = $this->getLogger(); $logger->info('{Message {nothing} {user} {foo.bar} a}', array('user' => 'Bob', 'foo.bar' => 'Bar')); $expected = array('info {Message {nothing} Bob Bar a}'); $this->assertEquals($expected, $this->getLogs()); } public function testObjectCastToString() { $dummy = $this->getMock('Psr\Log\Test\DummyTest', array('__toString')); $dummy->expects($this->once()) ->method('__toString') ->will($this->returnValue('DUMMY')); $this->getLogger()->warning($dummy); } public function testContextCanContainAnything() { $context = array( 'bool' => true, 'null' => null, 'string' => 'Foo', 'int' => 0, 'float' => 0.5, 'nested' => array('with object' => new DummyTest), 'object' => new \DateTime, 'resource' => fopen('php://memory', 'r'), ); $this->getLogger()->warning('Crazy context data', $context); } public function testContextExceptionKeyCanBeExceptionOrOtherValues() { $this->getLogger()->warning('Random message', array('exception' => 'oops')); $this->getLogger()->critical('Uncaught Exception!', array('exception' => new \LogicException('Fail'))); } } class DummyTest { } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * ApcClassLoader implements a wrapping autoloader cached in APC for PHP 5.3. * * It expects an object implementing a findFile method to find the file. This * allow using it as a wrapper around the other loaders of the component (the * ClassLoader and the UniversalClassLoader for instance) but also around any * other autoloader following this convention (the Composer one for instance) * * $loader = new ClassLoader(); * * // register classes with namespaces * $loader->add('Symfony\Component', __DIR__.'/component'); * $loader->add('Symfony', __DIR__.'/framework'); * * $cachedLoader = new ApcClassLoader('my_prefix', $loader); * * // activate the cached autoloader * $cachedLoader->register(); * * // eventually deactivate the non-cached loader if it was registered previously * // to be sure to use the cached one. * $loader->unregister(); * * @author Fabien Potencier * @author Kris Wallsmith * * @api */ class ApcClassLoader { private $prefix; /** * The class loader object being decorated. * * @var \Symfony\Component\ClassLoader\ClassLoader * A class loader object that implements the findFile() method. */ protected $decorated; /** * Constructor. * * @param string $prefix The APC namespace prefix to use. * @param object $decorated A class loader object that implements the findFile() method. * * @throws \RuntimeException * @throws \InvalidArgumentException * * @api */ public function __construct($prefix, $decorated) { if (!extension_loaded('apc')) { throw new \RuntimeException('Unable to use ApcClassLoader as APC is not enabled.'); } if (!method_exists($decorated, 'findFile')) { throw new \InvalidArgumentException('The class finder must implement a "findFile" method.'); } $this->prefix = $prefix; $this->decorated = $decorated; } /** * Registers this instance as an autoloader. * * @param Boolean $prepend Whether to prepend the autoloader or not */ public function register($prepend = false) { spl_autoload_register(array($this, 'loadClass'), true, $prepend); } /** * Unregisters this instance as an autoloader. */ public function unregister() { spl_autoload_unregister(array($this, 'loadClass')); } /** * Loads the given class or interface. * * @param string $class The name of the class * * @return Boolean|null True, if loaded */ public function loadClass($class) { if ($file = $this->findFile($class)) { require $file; return true; } } /** * Finds a file by class name while caching lookups to APC. * * @param string $class A class name to resolve to file * * @return string|null */ public function findFile($class) { if (false === $file = apc_fetch($this->prefix.$class)) { apc_store($this->prefix.$class, $file = $this->decorated->findFile($class)); } return $file; } /** * Passes through all unknown calls onto the decorated object. */ public function __call($method, $args) { return call_user_func_array(array($this->decorated, $method), $args); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * ApcUniversalClassLoader implements a "universal" autoloader cached in APC for PHP 5.3. * * It is able to load classes that use either: * * * The technical interoperability standards for PHP 5.3 namespaces and * class names (https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-0.md); * * * The PEAR naming convention for classes (http://pear.php.net/). * * Classes from a sub-namespace or a sub-hierarchy of PEAR classes can be * looked for in a list of locations to ease the vendoring of a sub-set of * classes for large projects. * * Example usage: * * require 'vendor/symfony/src/Symfony/Component/ClassLoader/UniversalClassLoader.php'; * require 'vendor/symfony/src/Symfony/Component/ClassLoader/ApcUniversalClassLoader.php'; * * use Symfony\Component\ClassLoader\ApcUniversalClassLoader; * * $loader = new ApcUniversalClassLoader('apc.prefix.'); * * // register classes with namespaces * $loader->registerNamespaces(array( * 'Symfony\Component' => __DIR__.'/component', * 'Symfony' => __DIR__.'/framework', * 'Sensio' => array(__DIR__.'/src', __DIR__.'/vendor'), * )); * * // register a library using the PEAR naming convention * $loader->registerPrefixes(array( * 'Swift_' => __DIR__.'/Swift', * )); * * // activate the autoloader * $loader->register(); * * In this example, if you try to use a class in the Symfony\Component * namespace or one of its children (Symfony\Component\Console for instance), * the autoloader will first look for the class under the component/ * directory, and it will then fallback to the framework/ directory if not * found before giving up. * * @author Fabien Potencier * @author Kris Wallsmith * * @api */ class ApcUniversalClassLoader extends UniversalClassLoader { private $prefix; /** * Constructor. * * @param string $prefix A prefix to create a namespace in APC * * @throws \RuntimeException * * @api */ public function __construct($prefix) { if (!extension_loaded('apc')) { throw new \RuntimeException('Unable to use ApcUniversalClassLoader as APC is not enabled.'); } $this->prefix = $prefix; } /** * Finds a file by class name while caching lookups to APC. * * @param string $class A class name to resolve to file * * @return string|null The path, if found */ public function findFile($class) { if (false === $file = apc_fetch($this->prefix.$class)) { apc_store($this->prefix.$class, $file = parent::findFile($class)); } return $file; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * ClassCollectionLoader. * * @author Fabien Potencier */ class ClassCollectionLoader { private static $loaded; private static $seen; private static $useTokenizer = true; /** * Loads a list of classes and caches them in one big file. * * @param array $classes An array of classes to load * @param string $cacheDir A cache directory * @param string $name The cache name prefix * @param Boolean $autoReload Whether to flush the cache when the cache is stale or not * @param Boolean $adaptive Whether to remove already declared classes or not * @param string $extension File extension of the resulting file * * @throws \InvalidArgumentException When class can't be loaded */ public static function load($classes, $cacheDir, $name, $autoReload, $adaptive = false, $extension = '.php') { // each $name can only be loaded once per PHP process if (isset(self::$loaded[$name])) { return; } self::$loaded[$name] = true; $declared = array_merge(get_declared_classes(), get_declared_interfaces()); if (function_exists('get_declared_traits')) { $declared = array_merge($declared, get_declared_traits()); } if ($adaptive) { // don't include already declared classes $classes = array_diff($classes, $declared); // the cache is different depending on which classes are already declared $name = $name.'-'.substr(hash('sha256', implode('|', $classes)), 0, 5); } $classes = array_unique($classes); $cache = $cacheDir.'/'.$name.$extension; // auto-reload $reload = false; if ($autoReload) { $metadata = $cache.'.meta'; if (!is_file($metadata) || !is_file($cache)) { $reload = true; } else { $time = filemtime($cache); $meta = unserialize(file_get_contents($metadata)); sort($meta[1]); sort($classes); if ($meta[1] != $classes) { $reload = true; } else { foreach ($meta[0] as $resource) { if (!is_file($resource) || filemtime($resource) > $time) { $reload = true; break; } } } } } if (!$reload && is_file($cache)) { require_once $cache; return; } $files = array(); $content = ''; foreach (self::getOrderedClasses($classes) as $class) { if (in_array($class->getName(), $declared)) { continue; } $files[] = $class->getFileName(); $c = preg_replace(array('/^\s*<\?php/', '/\?>\s*$/'), '', file_get_contents($class->getFileName())); // fakes namespace declaration for global code if (!$class->inNamespace()) { $c = "\nnamespace\n{\n".$c."\n}\n"; } $c = self::fixNamespaceDeclarations('getName()])) { return array(); } self::$seen[$class->getName()] = true; $classes = array($class); $parent = $class; while (($parent = $parent->getParentClass()) && $parent->isUserDefined() && !isset(self::$seen[$parent->getName()])) { self::$seen[$parent->getName()] = true; array_unshift($classes, $parent); } $traits = array(); if (function_exists('get_declared_traits')) { foreach ($classes as $c) { foreach (self::resolveDependencies(self::computeTraitDeps($c), $c) as $trait) { if ($trait !== $c) { $traits[] = $trait; } } } } return array_merge(self::getInterfaces($class), $traits, $classes); } private static function getInterfaces(\ReflectionClass $class) { $classes = array(); foreach ($class->getInterfaces() as $interface) { $classes = array_merge($classes, self::getInterfaces($interface)); } if ($class->isUserDefined() && $class->isInterface() && !isset(self::$seen[$class->getName()])) { self::$seen[$class->getName()] = true; $classes[] = $class; } return $classes; } private static function computeTraitDeps(\ReflectionClass $class) { $traits = $class->getTraits(); $deps = array($class->getName() => $traits); while ($trait = array_pop($traits)) { if ($trait->isUserDefined() && !isset(self::$seen[$trait->getName()])) { self::$seen[$trait->getName()] = true; $traitDeps = $trait->getTraits(); $deps[$trait->getName()] = $traitDeps; $traits = array_merge($traits, $traitDeps); } } return $deps; } /** * Dependencies resolution. * * This function does not check for circular dependencies as it should never * occur with PHP traits. * * @param array $tree The dependency tree * @param \ReflectionClass $node The node * @param \ArrayObject $resolved An array of already resolved dependencies * @param \ArrayObject $unresolved An array of dependencies to be resolved * * @return \ArrayObject The dependencies for the given node * * @throws \RuntimeException if a circular dependency is detected */ private static function resolveDependencies(array $tree, $node, \ArrayObject $resolved = null, \ArrayObject $unresolved = null) { if (null === $resolved) { $resolved = new \ArrayObject(); } if (null === $unresolved) { $unresolved = new \ArrayObject(); } $nodeName = $node->getName(); $unresolved[$nodeName] = $node; foreach ($tree[$nodeName] as $dependency) { if (!$resolved->offsetExists($dependency->getName())) { self::resolveDependencies($tree, $dependency, $resolved, $unresolved); } } $resolved[$nodeName] = $node; unset($unresolved[$nodeName]); return $resolved; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * ClassLoader implements an PSR-0 class loader * * See https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-0.md * * $loader = new ClassLoader(); * * // register classes with namespaces * $loader->addPrefix('Symfony\Component', __DIR__.'/component'); * $loader->addPrefix('Symfony', __DIR__.'/framework'); * * // activate the autoloader * $loader->register(); * * // to enable searching the include path (e.g. for PEAR packages) * $loader->setUseIncludePath(true); * * In this example, if you try to use a class in the Symfony\Component * namespace or one of its children (Symfony\Component\Console for instance), * the autoloader will first look for the class under the component/ * directory, and it will then fallback to the framework/ directory if not * found before giving up. * * @author Fabien Potencier * @author Jordi Boggiano */ class ClassLoader { private $prefixes = array(); private $fallbackDirs = array(); private $useIncludePath = false; /** * Returns prefixes. * * @return array */ public function getPrefixes() { return $this->prefixes; } /** * Returns fallback directories. * * @return array */ public function getFallbackDirs() { return $this->fallbackDirs; } /** * Adds prefixes. * * @param array $prefixes Prefixes to add */ public function addPrefixes(array $prefixes) { foreach ($prefixes as $prefix => $path) { $this->addPrefix($prefix, $path); } } /** * Registers a set of classes * * @param string $prefix The classes prefix * @param array|string $paths The location(s) of the classes */ public function addPrefix($prefix, $paths) { if (!$prefix) { foreach ((array) $paths as $path) { $this->fallbackDirs[] = $path; } return; } if (isset($this->prefixes[$prefix])) { $this->prefixes[$prefix] = array_merge( $this->prefixes[$prefix], (array) $paths ); } else { $this->prefixes[$prefix] = (array) $paths; } } /** * Turns on searching the include for class files. * * @param Boolean $useIncludePath */ public function setUseIncludePath($useIncludePath) { $this->useIncludePath = $useIncludePath; } /** * Can be used to check if the autoloader uses the include path to check * for classes. * * @return Boolean */ public function getUseIncludePath() { return $this->useIncludePath; } /** * Registers this instance as an autoloader. * * @param Boolean $prepend Whether to prepend the autoloader or not */ public function register($prepend = false) { spl_autoload_register(array($this, 'loadClass'), true, $prepend); } /** * Unregisters this instance as an autoloader. */ public function unregister() { spl_autoload_unregister(array($this, 'loadClass')); } /** * Loads the given class or interface. * * @param string $class The name of the class * * @return Boolean|null True, if loaded */ public function loadClass($class) { if ($file = $this->findFile($class)) { require $file; return true; } } /** * Finds the path to the file where the class is defined. * * @param string $class The name of the class * * @return string|null The path, if found */ public function findFile($class) { if (false !== $pos = strrpos($class, '\\')) { // namespaced class name $classPath = str_replace('\\', DIRECTORY_SEPARATOR, substr($class, 0, $pos)).DIRECTORY_SEPARATOR; $className = substr($class, $pos + 1); } else { // PEAR-like class name $classPath = null; $className = $class; } $classPath .= str_replace('_', DIRECTORY_SEPARATOR, $className).'.php'; foreach ($this->prefixes as $prefix => $dirs) { if ($class === strstr($class, $prefix)) { foreach ($dirs as $dir) { if (file_exists($dir.DIRECTORY_SEPARATOR.$classPath)) { return $dir.DIRECTORY_SEPARATOR.$classPath; } } } } foreach ($this->fallbackDirs as $dir) { if (file_exists($dir.DIRECTORY_SEPARATOR.$classPath)) { return $dir.DIRECTORY_SEPARATOR.$classPath; } } if ($this->useIncludePath && $file = stream_resolve_include_path($classPath)) { return $file; } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * ClassMapGenerator * * @author Gyula Sallai */ class ClassMapGenerator { /** * Generate a class map file * * @param array|string $dirs Directories or a single path to search in * @param string $file The name of the class map file */ public static function dump($dirs, $file) { $dirs = (array) $dirs; $maps = array(); foreach ($dirs as $dir) { $maps = array_merge($maps, static::createMap($dir)); } file_put_contents($file, sprintf('isFile()) { continue; } $path = $file->getRealPath(); if (pathinfo($path, PATHINFO_EXTENSION) !== 'php') { continue; } $classes = self::findClasses($path); foreach ($classes as $class) { $map[$class] = $path; } } return $map; } /** * Extract the classes in the given file * * @param string $path The file to check * * @return array The found classes */ private static function findClasses($path) { $contents = file_get_contents($path); $tokens = token_get_all($contents); $T_TRAIT = version_compare(PHP_VERSION, '5.4', '<') ? -1 : T_TRAIT; $classes = array(); $namespace = ''; for ($i = 0, $max = count($tokens); $i < $max; $i++) { $token = $tokens[$i]; if (is_string($token)) { continue; } $class = ''; switch ($token[0]) { case T_NAMESPACE: $namespace = ''; // If there is a namespace, extract it while (($t = $tokens[++$i]) && is_array($t)) { if (in_array($t[0], array(T_STRING, T_NS_SEPARATOR))) { $namespace .= $t[1]; } } $namespace .= '\\'; break; case T_CLASS: case T_INTERFACE: case $T_TRAIT: // Find the classname while (($t = $tokens[++$i]) && is_array($t)) { if (T_STRING === $t[0]) { $class .= $t[1]; } elseif ($class !== '' && T_WHITESPACE == $t[0]) { break; } } $classes[] = ltrim($namespace.$class, '\\'); break; default: break; } } return $classes; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * Autoloader checking if the class is really defined in the file found. * * The DebugClassLoader will wrap all registered autoloaders providing a * findFile method and will throw an exception if a file is found but does * not declare the class. * * @author Fabien Potencier * @author Christophe Coevoet * * @api * * @deprecated Deprecated since version 2.4, to be removed in 3.0. Use the DebugClassLoader provided by the Debug component instead. */ class DebugClassLoader { private $classFinder; /** * Constructor. * * @param object $classFinder * * @api */ public function __construct($classFinder) { $this->classFinder = $classFinder; } /** * Gets the wrapped class loader. * * @return object a class loader instance */ public function getClassLoader() { return $this->classFinder; } /** * Replaces all autoloaders implementing a findFile method by a DebugClassLoader wrapper. */ public static function enable() { if (!is_array($functions = spl_autoload_functions())) { return; } foreach ($functions as $function) { spl_autoload_unregister($function); } foreach ($functions as $function) { if (is_array($function) && !$function[0] instanceof self && method_exists($function[0], 'findFile')) { $function = array(new static($function[0]), 'loadClass'); } spl_autoload_register($function); } } /** * Unregisters this instance as an autoloader. */ public function unregister() { spl_autoload_unregister(array($this, 'loadClass')); } /** * Finds a file by class name * * @param string $class A class name to resolve to file * * @return string|null */ public function findFile($class) { return $this->classFinder->findFile($class); } /** * Loads the given class or interface. * * @param string $class The name of the class * * @return Boolean|null True, if loaded * * @throws \RuntimeException */ public function loadClass($class) { if ($file = $this->classFinder->findFile($class)) { require $file; if (!class_exists($class, false) && !interface_exists($class, false) && (!function_exists('trait_exists') || !trait_exists($class, false))) { if (false !== strpos($class, '/')) { throw new \RuntimeException(sprintf('Trying to autoload a class with an invalid name "%s". Be careful that the namespace separator is "\" in PHP, not "/".', $class)); } throw new \RuntimeException(sprintf('The autoloader expected class "%s" to be defined in file "%s". The file was found but the class was not in it, the class name or namespace probably has a typo.', $class, $file)); } return true; } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * Checks that the class is actually declared in the included file. * * @author Fabien Potencier */ class DebugUniversalClassLoader extends UniversalClassLoader { /** * Replaces all regular UniversalClassLoader instances by a DebugUniversalClassLoader ones. */ public static function enable() { if (!is_array($functions = spl_autoload_functions())) { return; } foreach ($functions as $function) { spl_autoload_unregister($function); } foreach ($functions as $function) { if (is_array($function) && $function[0] instanceof UniversalClassLoader) { $loader = new static(); $loader->registerNamespaceFallbacks($function[0]->getNamespaceFallbacks()); $loader->registerPrefixFallbacks($function[0]->getPrefixFallbacks()); $loader->registerNamespaces($function[0]->getNamespaces()); $loader->registerPrefixes($function[0]->getPrefixes()); $loader->useIncludePath($function[0]->getUseIncludePath()); $function[0] = $loader; } spl_autoload_register($function); } } /** * {@inheritDoc} */ public function loadClass($class) { if ($file = $this->findFile($class)) { require $file; if (!class_exists($class, false) && !interface_exists($class, false) && (!function_exists('trait_exists') || !trait_exists($class, false))) { throw new \RuntimeException(sprintf('The autoloader expected class "%s" to be defined in file "%s". The file was found but the class was not in it, the class name or namespace probably has a typo.', $class, $file)); } } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * A class loader that uses a mapping file to look up paths. * * @author Fabien Potencier */ class MapClassLoader { private $map = array(); /** * Constructor. * * @param array $map A map where keys are classes and values the absolute file path */ public function __construct(array $map) { $this->map = $map; } /** * Registers this instance as an autoloader. * * @param Boolean $prepend Whether to prepend the autoloader or not */ public function register($prepend = false) { spl_autoload_register(array($this, 'loadClass'), true, $prepend); } /** * Loads the given class or interface. * * @param string $class The name of the class */ public function loadClass($class) { if (isset($this->map[$class])) { require $this->map[$class]; } } /** * Finds the path to the file where the class is defined. * * @param string $class The name of the class * * @return string|null The path, if found */ public function findFile($class) { if (isset($this->map[$class])) { return $this->map[$class]; } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader\Tests; use Symfony\Component\ClassLoader\ApcUniversalClassLoader; class ApcUniversalClassLoaderTest extends \PHPUnit_Framework_TestCase { protected function setUp() { if (!extension_loaded('apc')) { $this->markTestSkipped('The apc extension is not available.'); } if (!(ini_get('apc.enabled') && ini_get('apc.enable_cli'))) { $this->markTestSkipped('The apc extension is available, but not enabled.'); } else { apc_clear_cache('user'); } } protected function tearDown() { if (ini_get('apc.enabled') && ini_get('apc.enable_cli')) { apc_clear_cache('user'); } } public function testConstructor() { $loader = new ApcUniversalClassLoader('test.prefix.'); $loader->registerNamespace('Apc\Namespaced', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $this->assertEquals($loader->findFile('\Apc\Namespaced\FooBar'), apc_fetch('test.prefix.\Apc\Namespaced\FooBar'), '__construct() takes a prefix as its first argument'); } /** * @dataProvider getLoadClassTests */ public function testLoadClass($className, $testClassName, $message) { $loader = new ApcUniversalClassLoader('test.prefix.'); $loader->registerNamespace('Apc\Namespaced', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerPrefix('Apc_Pearlike_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->loadClass($testClassName); $this->assertTrue(class_exists($className), $message); } public function getLoadClassTests() { return array( array('\\Apc\\Namespaced\\Foo', '\\Apc\\Namespaced\\Foo', '->loadClass() loads Apc\Namespaced\Foo class'), array('Apc_Pearlike_Foo', 'Apc_Pearlike_Foo', '->loadClass() loads Apc_Pearlike_Foo class'), array('\\Apc\\Namespaced\\Bar', '\\Apc\\Namespaced\\Bar', '->loadClass() loads Apc\Namespaced\Bar class with a leading slash'), array('Apc_Pearlike_Bar', '\\Apc_Pearlike_Bar', '->loadClass() loads Apc_Pearlike_Bar class with a leading slash'), ); } /** * @dataProvider getLoadClassFromFallbackTests */ public function testLoadClassFromFallback($className, $testClassName, $message) { $loader = new ApcUniversalClassLoader('test.prefix.fallback'); $loader->registerNamespace('Apc\Namespaced', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerPrefix('Apc_Pearlike_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerNamespaceFallbacks(array(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/fallback')); $loader->registerPrefixFallbacks(array(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/fallback')); $loader->loadClass($testClassName); $this->assertTrue(class_exists($className), $message); } public function getLoadClassFromFallbackTests() { return array( array('\\Apc\\Namespaced\\Baz', '\\Apc\\Namespaced\\Baz', '->loadClass() loads Apc\Namespaced\Baz class'), array('Apc_Pearlike_Baz', 'Apc_Pearlike_Baz', '->loadClass() loads Apc_Pearlike_Baz class'), array('\\Apc\\Namespaced\\FooBar', '\\Apc\\Namespaced\\FooBar', '->loadClass() loads Apc\Namespaced\Baz class from fallback dir'), array('Apc_Pearlike_FooBar', 'Apc_Pearlike_FooBar', '->loadClass() loads Apc_Pearlike_Baz class from fallback dir'), ); } /** * @dataProvider getLoadClassNamespaceCollisionTests */ public function testLoadClassNamespaceCollision($namespaces, $className, $message) { $loader = new ApcUniversalClassLoader('test.prefix.collision.'); $loader->registerNamespaces($namespaces); $loader->loadClass($className); $this->assertTrue(class_exists($className), $message); } public function getLoadClassNamespaceCollisionTests() { return array( array( array( 'Apc\\NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha', 'Apc\\NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta', ), '\Apc\NamespaceCollision\A\Foo', '->loadClass() loads NamespaceCollision\A\Foo from alpha.', ), array( array( 'Apc\\NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta', 'Apc\\NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha', ), '\Apc\NamespaceCollision\A\Bar', '->loadClass() loads NamespaceCollision\A\Bar from alpha.', ), array( array( 'Apc\\NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha', 'Apc\\NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta', ), '\Apc\NamespaceCollision\A\B\Foo', '->loadClass() loads NamespaceCollision\A\B\Foo from beta.', ), array( array( 'Apc\\NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta', 'Apc\\NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha', ), '\Apc\NamespaceCollision\A\B\Bar', '->loadClass() loads NamespaceCollision\A\B\Bar from beta.', ), ); } /** * @dataProvider getLoadClassPrefixCollisionTests */ public function testLoadClassPrefixCollision($prefixes, $className, $message) { $loader = new ApcUniversalClassLoader('test.prefix.collision.'); $loader->registerPrefixes($prefixes); $loader->loadClass($className); $this->assertTrue(class_exists($className), $message); } public function getLoadClassPrefixCollisionTests() { return array( array( array( 'ApcPrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha/Apc', 'ApcPrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta/Apc', ), 'ApcPrefixCollision_A_Foo', '->loadClass() loads ApcPrefixCollision_A_Foo from alpha.', ), array( array( 'ApcPrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta/Apc', 'ApcPrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha/Apc', ), 'ApcPrefixCollision_A_Bar', '->loadClass() loads ApcPrefixCollision_A_Bar from alpha.', ), array( array( 'ApcPrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha/Apc', 'ApcPrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta/Apc', ), 'ApcPrefixCollision_A_B_Foo', '->loadClass() loads ApcPrefixCollision_A_B_Foo from beta.', ), array( array( 'ApcPrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta/Apc', 'ApcPrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha/Apc', ), 'ApcPrefixCollision_A_B_Bar', '->loadClass() loads ApcPrefixCollision_A_B_Bar from beta.', ), ); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader\Tests; use Symfony\Component\ClassLoader\ClassCollectionLoader; require_once __DIR__.'/Fixtures/ClassesWithParents/GInterface.php'; require_once __DIR__.'/Fixtures/ClassesWithParents/CInterface.php'; require_once __DIR__.'/Fixtures/ClassesWithParents/B.php'; require_once __DIR__.'/Fixtures/ClassesWithParents/A.php'; class ClassCollectionLoaderTest extends \PHPUnit_Framework_TestCase { public function testTraitDependencies() { if (version_compare(phpversion(), '5.4', '<')) { $this->markTestSkipped('Requires PHP > 5.4'); return; } require_once __DIR__.'/Fixtures/deps/traits.php'; $r = new \ReflectionClass('Symfony\Component\ClassLoader\ClassCollectionLoader'); $m = $r->getMethod('getOrderedClasses'); $m->setAccessible(true); $ordered = $m->invoke('Symfony\Component\ClassLoader\ClassCollectionLoader', array('CTFoo')); $this->assertEquals( array('TD', 'TC', 'TB', 'TA', 'TZ', 'CTFoo'), array_map(function ($class) { return $class->getName(); }, $ordered) ); $ordered = $m->invoke('Symfony\Component\ClassLoader\ClassCollectionLoader', array('CTBar')); $this->assertEquals( array('TD', 'TZ', 'TC', 'TB', 'TA', 'CTBar'), array_map(function ($class) { return $class->getName(); }, $ordered) ); } /** * @dataProvider getDifferentOrders */ public function testClassReordering(array $classes) { $expected = array( 'ClassesWithParents\\GInterface', 'ClassesWithParents\\CInterface', 'ClassesWithParents\\B', 'ClassesWithParents\\A', ); $r = new \ReflectionClass('Symfony\Component\ClassLoader\ClassCollectionLoader'); $m = $r->getMethod('getOrderedClasses'); $m->setAccessible(true); $ordered = $m->invoke('Symfony\Component\ClassLoader\ClassCollectionLoader', $classes); $this->assertEquals($expected, array_map(function ($class) { return $class->getName(); }, $ordered)); } public function getDifferentOrders() { return array( array(array( 'ClassesWithParents\\A', 'ClassesWithParents\\CInterface', 'ClassesWithParents\\GInterface', 'ClassesWithParents\\B', )), array(array( 'ClassesWithParents\\B', 'ClassesWithParents\\A', 'ClassesWithParents\\CInterface', )), array(array( 'ClassesWithParents\\CInterface', 'ClassesWithParents\\B', 'ClassesWithParents\\A', )), array(array( 'ClassesWithParents\\A', )), ); } /** * @dataProvider getDifferentOrdersForTraits */ public function testClassWithTraitsReordering(array $classes) { if (version_compare(phpversion(), '5.4', '<')) { $this->markTestSkipped('Requires PHP > 5.4'); return; } require_once __DIR__.'/Fixtures/ClassesWithParents/ATrait.php'; require_once __DIR__.'/Fixtures/ClassesWithParents/BTrait.php'; require_once __DIR__.'/Fixtures/ClassesWithParents/CTrait.php'; require_once __DIR__.'/Fixtures/ClassesWithParents/D.php'; require_once __DIR__.'/Fixtures/ClassesWithParents/E.php'; $expected = array( 'ClassesWithParents\\GInterface', 'ClassesWithParents\\CInterface', 'ClassesWithParents\\ATrait', 'ClassesWithParents\\BTrait', 'ClassesWithParents\\CTrait', 'ClassesWithParents\\B', 'ClassesWithParents\\A', 'ClassesWithParents\\D', 'ClassesWithParents\\E', ); $r = new \ReflectionClass('Symfony\Component\ClassLoader\ClassCollectionLoader'); $m = $r->getMethod('getOrderedClasses'); $m->setAccessible(true); $ordered = $m->invoke('Symfony\Component\ClassLoader\ClassCollectionLoader', $classes); $this->assertEquals($expected, array_map(function ($class) { return $class->getName(); }, $ordered)); } public function getDifferentOrdersForTraits() { return array( array(array( 'ClassesWithParents\\E', 'ClassesWithParents\\ATrait', )), array(array( 'ClassesWithParents\\E', )), ); } /** * @dataProvider getFixNamespaceDeclarationsData */ public function testFixNamespaceDeclarations($source, $expected) { $this->assertEquals('assertEquals('assertEquals(<< * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader\Tests; use Symfony\Component\ClassLoader\ClassLoader; class ClassLoaderTest extends \PHPUnit_Framework_TestCase { public function testGetPrefixes() { $loader = new ClassLoader(); $loader->addPrefix('Foo', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->addPrefix('Bar', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->addPrefix('Bas', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $prefixes = $loader->getPrefixes(); $this->assertArrayHasKey('Foo', $prefixes); $this->assertArrayNotHasKey('Foo1', $prefixes); $this->assertArrayHasKey('Bar', $prefixes); $this->assertArrayHasKey('Bas', $prefixes); } public function testGetFallbackDirs() { $loader = new ClassLoader(); $loader->addPrefix(null, __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->addPrefix(null, __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $fallback_dirs = $loader->getFallbackDirs(); $this->assertCount(2, $fallback_dirs); } /** * @dataProvider getLoadClassTests */ public function testLoadClass($className, $testClassName, $message) { $loader = new ClassLoader(); $loader->addPrefix('Namespaced2\\', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->addPrefix('Pearlike2_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->loadClass($testClassName); $this->assertTrue(class_exists($className), $message); } public function getLoadClassTests() { return array( array('\\Namespaced2\\Foo', 'Namespaced2\\Foo', '->loadClass() loads Namespaced2\Foo class'), array('\\Pearlike2_Foo', 'Pearlike2_Foo', '->loadClass() loads Pearlike2_Foo class'), ); } /** * @dataProvider getLoadNonexistentClassTests */ public function testLoadNonexistentClass($className, $testClassName, $message) { $loader = new ClassLoader(); $loader->addPrefix('Namespaced2\\', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->addPrefix('Pearlike2_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->loadClass($testClassName); $this->assertFalse(class_exists($className), $message); } public function getLoadNonexistentClassTests() { return array( array('\\Pearlike3_Bar', '\\Pearlike3_Bar', '->loadClass() loads non existing Pearlike3_Bar class with a leading slash'), ); } public function testAddPrefix() { $loader = new ClassLoader(); $loader->addPrefix('Foo', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->addPrefix('Foo', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $prefixes = $loader->getPrefixes(); $this->assertArrayHasKey('Foo', $prefixes); $this->assertCount(2, $prefixes['Foo']); } public function testUseIncludePath() { $loader = new ClassLoader(); $this->assertFalse($loader->getUseIncludePath()); $this->assertNull($loader->findFile('Foo')); $includePath = get_include_path(); $loader->setUseIncludePath(true); $this->assertTrue($loader->getUseIncludePath()); set_include_path(__DIR__.'/Fixtures/includepath'.PATH_SEPARATOR.$includePath); $this->assertEquals(__DIR__.DIRECTORY_SEPARATOR.'Fixtures'.DIRECTORY_SEPARATOR.'includepath'.DIRECTORY_SEPARATOR.'Foo.php', $loader->findFile('Foo')); set_include_path($includePath); } /** * @dataProvider getLoadClassFromFallbackTests */ public function testLoadClassFromFallback($className, $testClassName, $message) { $loader = new ClassLoader(); $loader->addPrefix('Namespaced2\\', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->addPrefix('Pearlike2_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->addPrefix('', array(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/fallback')); $loader->loadClass($testClassName); $this->assertTrue(class_exists($className), $message); } public function getLoadClassFromFallbackTests() { return array( array('\\Namespaced2\\Baz', 'Namespaced2\\Baz', '->loadClass() loads Namespaced2\Baz class'), array('\\Pearlike2_Baz', 'Pearlike2_Baz', '->loadClass() loads Pearlike2_Baz class'), array('\\Namespaced2\\FooBar', 'Namespaced2\\FooBar', '->loadClass() loads Namespaced2\Baz class from fallback dir'), array('\\Pearlike2_FooBar', 'Pearlike2_FooBar', '->loadClass() loads Pearlike2_Baz class from fallback dir'), ); } /** * @dataProvider getLoadClassNamespaceCollisionTests */ public function testLoadClassNamespaceCollision($namespaces, $className, $message) { $loader = new ClassLoader(); $loader->addPrefixes($namespaces); $loader->loadClass($className); $this->assertTrue(class_exists($className), $message); } public function getLoadClassNamespaceCollisionTests() { return array( array( array( 'NamespaceCollision\\C' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', 'NamespaceCollision\\C\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', ), 'NamespaceCollision\C\Foo', '->loadClass() loads NamespaceCollision\C\Foo from alpha.', ), array( array( 'NamespaceCollision\\C\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', 'NamespaceCollision\\C' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', ), 'NamespaceCollision\C\Bar', '->loadClass() loads NamespaceCollision\C\Bar from alpha.', ), array( array( 'NamespaceCollision\\C' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', 'NamespaceCollision\\C\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', ), 'NamespaceCollision\C\B\Foo', '->loadClass() loads NamespaceCollision\C\B\Foo from beta.', ), array( array( 'NamespaceCollision\\C\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', 'NamespaceCollision\\C' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', ), 'NamespaceCollision\C\B\Bar', '->loadClass() loads NamespaceCollision\C\B\Bar from beta.', ), array( array( 'PrefixCollision_C_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', 'PrefixCollision_C_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', ), 'PrefixCollision_C_Foo', '->loadClass() loads PrefixCollision_C_Foo from alpha.', ), array( array( 'PrefixCollision_C_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', 'PrefixCollision_C_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', ), 'PrefixCollision_C_Bar', '->loadClass() loads PrefixCollision_C_Bar from alpha.', ), array( array( 'PrefixCollision_C_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', 'PrefixCollision_C_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', ), 'PrefixCollision_C_B_Foo', '->loadClass() loads PrefixCollision_C_B_Foo from beta.', ), array( array( 'PrefixCollision_C_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', 'PrefixCollision_C_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', ), 'PrefixCollision_C_B_Bar', '->loadClass() loads PrefixCollision_C_B_Bar from beta.', ), ); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader\Tests; use Symfony\Component\ClassLoader\ClassMapGenerator; class ClassMapGeneratorTest extends \PHPUnit_Framework_TestCase { /** * @var string $workspace */ private $workspace = null; public function prepare_workspace() { $this->workspace = rtrim(sys_get_temp_dir(), DIRECTORY_SEPARATOR).DIRECTORY_SEPARATOR.time().rand(0, 1000); mkdir($this->workspace, 0777, true); $this->workspace = realpath($this->workspace); } /** * @param string $file */ private function clean($file) { if (is_dir($file) && !is_link($file)) { $dir = new \FilesystemIterator($file); foreach ($dir as $childFile) { $this->clean($childFile); } rmdir($file); } else { unlink($file); } } /** * @dataProvider getTestCreateMapTests */ public function testDump($directory, $expected) { $this->prepare_workspace(); $file = $this->workspace.'/file'; $generator = new ClassMapGenerator(); $generator->dump($directory, $file); $this->assertFileExists($file); $this->clean($this->workspace); } /** * @dataProvider getTestCreateMapTests */ public function testCreateMap($directory, $expected) { $this->assertEqualsNormalized($expected, ClassMapGenerator::createMap($directory)); } public function getTestCreateMapTests() { $data = array( array(__DIR__.'/Fixtures/Namespaced', array( 'Namespaced\\Bar' => realpath(__DIR__).'/Fixtures/Namespaced/Bar.php', 'Namespaced\\Foo' => realpath(__DIR__).'/Fixtures/Namespaced/Foo.php', 'Namespaced\\Baz' => realpath(__DIR__).'/Fixtures/Namespaced/Baz.php', 'Namespaced\\WithComments' => realpath(__DIR__).'/Fixtures/Namespaced/WithComments.php', ) ), array(__DIR__.'/Fixtures/beta/NamespaceCollision', array( 'NamespaceCollision\\A\\B\\Bar' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/A/B/Bar.php', 'NamespaceCollision\\A\\B\\Foo' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/A/B/Foo.php', 'NamespaceCollision\\C\\B\\Bar' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/C/B/Bar.php', 'NamespaceCollision\\C\\B\\Foo' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/C/B/Foo.php', )), array(__DIR__.'/Fixtures/Pearlike', array( 'Pearlike_Foo' => realpath(__DIR__).'/Fixtures/Pearlike/Foo.php', 'Pearlike_Bar' => realpath(__DIR__).'/Fixtures/Pearlike/Bar.php', 'Pearlike_Baz' => realpath(__DIR__).'/Fixtures/Pearlike/Baz.php', 'Pearlike_WithComments' => realpath(__DIR__).'/Fixtures/Pearlike/WithComments.php', )), array(__DIR__.'/Fixtures/classmap', array( 'Foo\\Bar\\A' => realpath(__DIR__).'/Fixtures/classmap/sameNsMultipleClasses.php', 'Foo\\Bar\\B' => realpath(__DIR__).'/Fixtures/classmap/sameNsMultipleClasses.php', 'A' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', 'Alpha\\A' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', 'Alpha\\B' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', 'Beta\\A' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', 'Beta\\B' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', 'ClassMap\\SomeInterface' => realpath(__DIR__).'/Fixtures/classmap/SomeInterface.php', 'ClassMap\\SomeParent' => realpath(__DIR__).'/Fixtures/classmap/SomeParent.php', 'ClassMap\\SomeClass' => realpath(__DIR__).'/Fixtures/classmap/SomeClass.php', )), ); if (version_compare(PHP_VERSION, '5.4', '>=')) { $data[] = array(__DIR__.'/Fixtures/php5.4', array( 'TFoo' => __DIR__.'/Fixtures/php5.4/traits.php', 'CFoo' => __DIR__.'/Fixtures/php5.4/traits.php', 'Foo\\TBar' => __DIR__.'/Fixtures/php5.4/traits.php', 'Foo\\IBar' => __DIR__.'/Fixtures/php5.4/traits.php', 'Foo\\TFooBar' => __DIR__.'/Fixtures/php5.4/traits.php', 'Foo\\CBar' => __DIR__.'/Fixtures/php5.4/traits.php', )); } return $data; } public function testCreateMapFinderSupport() { $finder = new \Symfony\Component\Finder\Finder(); $finder->files()->in(__DIR__.'/Fixtures/beta/NamespaceCollision'); $this->assertEqualsNormalized(array( 'NamespaceCollision\\A\\B\\Bar' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/A/B/Bar.php', 'NamespaceCollision\\A\\B\\Foo' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/A/B/Foo.php', 'NamespaceCollision\\C\\B\\Bar' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/C/B/Bar.php', 'NamespaceCollision\\C\\B\\Foo' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/C/B/Foo.php', ), ClassMapGenerator::createMap($finder)); } protected function assertEqualsNormalized($expected, $actual, $message = null) { foreach ($expected as $ns => $path) { $expected[$ns] = strtr($path, '\\', '/'); } foreach ($actual as $ns => $path) { $actual[$ns] = strtr($path, '\\', '/'); } $this->assertEquals($expected, $actual, $message); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace NamespaceCollision\A; class Bar { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace NamespaceCollision\A; class Foo { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Apc\NamespaceCollision\A; class Bar { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Apc\NamespaceCollision\A; class Foo { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Apc\NamespaceCollision\A\B; class Bar { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Apc\NamespaceCollision\A\B; class Foo { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Apc\Namespaced; class FooBar { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Apc\Namespaced; class Bar { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Apc\Namespaced; class Baz { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Apc\Namespaced; class Foo { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Apc\Namespaced; class FooBar { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace NamespaceCollision\A\B; class Bar { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace NamespaceCollision\A\B; class Foo { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Foo\Bar; class A {} class B {} * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace ClassMap; class SomeClass extends SomeParent implements SomeInterface { } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace ClassMap; interface SomeInterface { } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace ClassMap; abstract class SomeParent { } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Namespaced; class FooBar { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Namespaced; class Bar { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Namespaced; class Baz { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Namespaced; class Foo { public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Namespaced; class WithComments { /** @Boolean */ public static $loaded = true; } $string = 'string shoult not be modified {$string}'; $heredoc = (<< * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ class Pearlike_WithComments { /** @Boolean */ public static $loaded = true; } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader\Tests; use Symfony\Component\ClassLoader\UniversalClassLoader; class UniversalClassLoaderTest extends \PHPUnit_Framework_TestCase { /** * @dataProvider getLoadClassTests */ public function testLoadClass($className, $testClassName, $message) { $loader = new UniversalClassLoader(); $loader->registerNamespace('Namespaced', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerPrefix('Pearlike_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $this->assertTrue($loader->loadClass($testClassName)); $this->assertTrue(class_exists($className), $message); } public function getLoadClassTests() { return array( array('\\Namespaced\\Foo', 'Namespaced\\Foo', '->loadClass() loads Namespaced\Foo class'), array('\\Pearlike_Foo', 'Pearlike_Foo', '->loadClass() loads Pearlike_Foo class'), ); } public function testUseIncludePath() { $loader = new UniversalClassLoader(); $this->assertFalse($loader->getUseIncludePath()); $this->assertNull($loader->findFile('Foo')); $includePath = get_include_path(); $loader->useIncludePath(true); $this->assertTrue($loader->getUseIncludePath()); set_include_path(__DIR__.'/Fixtures/includepath'.PATH_SEPARATOR.$includePath); $this->assertEquals(__DIR__.DIRECTORY_SEPARATOR.'Fixtures'.DIRECTORY_SEPARATOR.'includepath'.DIRECTORY_SEPARATOR.'Foo.php', $loader->findFile('Foo')); set_include_path($includePath); } public function testGetNamespaces() { $loader = new UniversalClassLoader(); $loader->registerNamespace('Foo', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerNamespace('Bar', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerNamespace('Bas', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $namespaces = $loader->getNamespaces(); $this->assertArrayHasKey('Foo', $namespaces); $this->assertArrayNotHasKey('Foo1', $namespaces); $this->assertArrayHasKey('Bar', $namespaces); $this->assertArrayHasKey('Bas', $namespaces); } public function testGetPrefixes() { $loader = new UniversalClassLoader(); $loader->registerPrefix('Foo', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerPrefix('Bar', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerPrefix('Bas', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $prefixes = $loader->getPrefixes(); $this->assertArrayHasKey('Foo', $prefixes); $this->assertArrayNotHasKey('Foo1', $prefixes); $this->assertArrayHasKey('Bar', $prefixes); $this->assertArrayHasKey('Bas', $prefixes); } /** * @dataProvider getLoadClassFromFallbackTests */ public function testLoadClassFromFallback($className, $testClassName, $message) { $loader = new UniversalClassLoader(); $loader->registerNamespace('Namespaced', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerPrefix('Pearlike_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); $loader->registerNamespaceFallbacks(array(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/fallback')); $loader->registerPrefixFallbacks(array(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/fallback')); $this->assertTrue($loader->loadClass($testClassName)); $this->assertTrue(class_exists($className), $message); } public function getLoadClassFromFallbackTests() { return array( array('\\Namespaced\\Baz', 'Namespaced\\Baz', '->loadClass() loads Namespaced\Baz class'), array('\\Pearlike_Baz', 'Pearlike_Baz', '->loadClass() loads Pearlike_Baz class'), array('\\Namespaced\\FooBar', 'Namespaced\\FooBar', '->loadClass() loads Namespaced\Baz class from fallback dir'), array('\\Pearlike_FooBar', 'Pearlike_FooBar', '->loadClass() loads Pearlike_Baz class from fallback dir'), ); } public function testRegisterPrefixFallback() { $loader = new UniversalClassLoader(); $loader->registerPrefixFallback(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/fallback'); $this->assertEquals(array(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/fallback'), $loader->getPrefixFallbacks()); } public function testRegisterNamespaceFallback() { $loader = new UniversalClassLoader(); $loader->registerNamespaceFallback(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/Namespaced/fallback'); $this->assertEquals(array(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/Namespaced/fallback'), $loader->getNamespaceFallbacks()); } /** * @dataProvider getLoadClassNamespaceCollisionTests */ public function testLoadClassNamespaceCollision($namespaces, $className, $message) { $loader = new UniversalClassLoader(); $loader->registerNamespaces($namespaces); $this->assertTrue($loader->loadClass($className)); $this->assertTrue(class_exists($className), $message); } public function getLoadClassNamespaceCollisionTests() { return array( array( array( 'NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', 'NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', ), 'NamespaceCollision\A\Foo', '->loadClass() loads NamespaceCollision\A\Foo from alpha.', ), array( array( 'NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', 'NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', ), 'NamespaceCollision\A\Bar', '->loadClass() loads NamespaceCollision\A\Bar from alpha.', ), array( array( 'NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', 'NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', ), 'NamespaceCollision\A\B\Foo', '->loadClass() loads NamespaceCollision\A\B\Foo from beta.', ), array( array( 'NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', 'NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', ), 'NamespaceCollision\A\B\Bar', '->loadClass() loads NamespaceCollision\A\B\Bar from beta.', ), ); } /** * @dataProvider getLoadClassPrefixCollisionTests */ public function testLoadClassPrefixCollision($prefixes, $className, $message) { $loader = new UniversalClassLoader(); $loader->registerPrefixes($prefixes); $this->assertTrue($loader->loadClass($className)); $this->assertTrue(class_exists($className), $message); } public function getLoadClassPrefixCollisionTests() { return array( array( array( 'PrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', 'PrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', ), 'PrefixCollision_A_Foo', '->loadClass() loads PrefixCollision_A_Foo from alpha.', ), array( array( 'PrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', 'PrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', ), 'PrefixCollision_A_Bar', '->loadClass() loads PrefixCollision_A_Bar from alpha.', ), array( array( 'PrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', 'PrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', ), 'PrefixCollision_A_B_Foo', '->loadClass() loads PrefixCollision_A_B_Foo from beta.', ), array( array( 'PrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', 'PrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', ), 'PrefixCollision_A_B_Bar', '->loadClass() loads PrefixCollision_A_B_Bar from beta.', ), ); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * UniversalClassLoader implements a "universal" autoloader for PHP 5.3. * * It is able to load classes that use either: * * * The technical interoperability standards for PHP 5.3 namespaces and * class names (https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-0.md); * * * The PEAR naming convention for classes (http://pear.php.net/). * * Classes from a sub-namespace or a sub-hierarchy of PEAR classes can be * looked for in a list of locations to ease the vendoring of a sub-set of * classes for large projects. * * Example usage: * * $loader = new UniversalClassLoader(); * * // register classes with namespaces * $loader->registerNamespaces(array( * 'Symfony\Component' => __DIR__.'/component', * 'Symfony' => __DIR__.'/framework', * 'Sensio' => array(__DIR__.'/src', __DIR__.'/vendor'), * )); * * // register a library using the PEAR naming convention * $loader->registerPrefixes(array( * 'Swift_' => __DIR__.'/Swift', * )); * * * // to enable searching the include path (e.g. for PEAR packages) * $loader->useIncludePath(true); * * // activate the autoloader * $loader->register(); * * In this example, if you try to use a class in the Symfony\Component * namespace or one of its children (Symfony\Component\Console for instance), * the autoloader will first look for the class under the component/ * directory, and it will then fallback to the framework/ directory if not * found before giving up. * * @author Fabien Potencier * * @api */ class UniversalClassLoader { private $namespaces = array(); private $prefixes = array(); private $namespaceFallbacks = array(); private $prefixFallbacks = array(); private $useIncludePath = false; /** * Turns on searching the include for class files. Allows easy loading * of installed PEAR packages * * @param Boolean $useIncludePath */ public function useIncludePath($useIncludePath) { $this->useIncludePath = $useIncludePath; } /** * Can be used to check if the autoloader uses the include path to check * for classes. * * @return Boolean */ public function getUseIncludePath() { return $this->useIncludePath; } /** * Gets the configured namespaces. * * @return array A hash with namespaces as keys and directories as values */ public function getNamespaces() { return $this->namespaces; } /** * Gets the configured class prefixes. * * @return array A hash with class prefixes as keys and directories as values */ public function getPrefixes() { return $this->prefixes; } /** * Gets the directory(ies) to use as a fallback for namespaces. * * @return array An array of directories */ public function getNamespaceFallbacks() { return $this->namespaceFallbacks; } /** * Gets the directory(ies) to use as a fallback for class prefixes. * * @return array An array of directories */ public function getPrefixFallbacks() { return $this->prefixFallbacks; } /** * Registers the directory to use as a fallback for namespaces. * * @param array $dirs An array of directories * * @api */ public function registerNamespaceFallbacks(array $dirs) { $this->namespaceFallbacks = $dirs; } /** * Registers a directory to use as a fallback for namespaces. * * @param string $dir A directory */ public function registerNamespaceFallback($dir) { $this->namespaceFallbacks[] = $dir; } /** * Registers directories to use as a fallback for class prefixes. * * @param array $dirs An array of directories * * @api */ public function registerPrefixFallbacks(array $dirs) { $this->prefixFallbacks = $dirs; } /** * Registers a directory to use as a fallback for class prefixes. * * @param string $dir A directory */ public function registerPrefixFallback($dir) { $this->prefixFallbacks[] = $dir; } /** * Registers an array of namespaces * * @param array $namespaces An array of namespaces (namespaces as keys and locations as values) * * @api */ public function registerNamespaces(array $namespaces) { foreach ($namespaces as $namespace => $locations) { $this->namespaces[$namespace] = (array) $locations; } } /** * Registers a namespace. * * @param string $namespace The namespace * @param array|string $paths The location(s) of the namespace * * @api */ public function registerNamespace($namespace, $paths) { $this->namespaces[$namespace] = (array) $paths; } /** * Registers an array of classes using the PEAR naming convention. * * @param array $classes An array of classes (prefixes as keys and locations as values) * * @api */ public function registerPrefixes(array $classes) { foreach ($classes as $prefix => $locations) { $this->prefixes[$prefix] = (array) $locations; } } /** * Registers a set of classes using the PEAR naming convention. * * @param string $prefix The classes prefix * @param array|string $paths The location(s) of the classes * * @api */ public function registerPrefix($prefix, $paths) { $this->prefixes[$prefix] = (array) $paths; } /** * Registers this instance as an autoloader. * * @param Boolean $prepend Whether to prepend the autoloader or not * * @api */ public function register($prepend = false) { spl_autoload_register(array($this, 'loadClass'), true, $prepend); } /** * Loads the given class or interface. * * @param string $class The name of the class * * @return Boolean|null True, if loaded */ public function loadClass($class) { if ($file = $this->findFile($class)) { require $file; return true; } } /** * Finds the path to the file where the class is defined. * * @param string $class The name of the class * * @return string|null The path, if found */ public function findFile($class) { if (false !== $pos = strrpos($class, '\\')) { // namespaced class name $namespace = substr($class, 0, $pos); $className = substr($class, $pos + 1); $normalizedClass = str_replace('\\', DIRECTORY_SEPARATOR, $namespace).DIRECTORY_SEPARATOR.str_replace('_', DIRECTORY_SEPARATOR, $className).'.php'; foreach ($this->namespaces as $ns => $dirs) { if (0 !== strpos($namespace, $ns)) { continue; } foreach ($dirs as $dir) { $file = $dir.DIRECTORY_SEPARATOR.$normalizedClass; if (is_file($file)) { return $file; } } } foreach ($this->namespaceFallbacks as $dir) { $file = $dir.DIRECTORY_SEPARATOR.$normalizedClass; if (is_file($file)) { return $file; } } } else { // PEAR-like class name $normalizedClass = str_replace('_', DIRECTORY_SEPARATOR, $class).'.php'; foreach ($this->prefixes as $prefix => $dirs) { if (0 !== strpos($class, $prefix)) { continue; } foreach ($dirs as $dir) { $file = $dir.DIRECTORY_SEPARATOR.$normalizedClass; if (is_file($file)) { return $file; } } } foreach ($this->prefixFallbacks as $dir) { $file = $dir.DIRECTORY_SEPARATOR.$normalizedClass; if (is_file($file)) { return $file; } } } if ($this->useIncludePath && $file = stream_resolve_include_path($normalizedClass)) { return $file; } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * WinCacheClassLoader implements a wrapping autoloader cached in WinCache. * * It expects an object implementing a findFile method to find the file. This * allow using it as a wrapper around the other loaders of the component (the * ClassLoader and the UniversalClassLoader for instance) but also around any * other autoloader following this convention (the Composer one for instance) * * $loader = new ClassLoader(); * * // register classes with namespaces * $loader->add('Symfony\Component', __DIR__.'/component'); * $loader->add('Symfony', __DIR__.'/framework'); * * $cachedLoader = new WinCacheClassLoader('my_prefix', $loader); * * // activate the cached autoloader * $cachedLoader->register(); * * // eventually deactivate the non-cached loader if it was registered previously * // to be sure to use the cached one. * $loader->unregister(); * * @author Fabien Potencier * @author Kris Wallsmith * @author Artem Ryzhkov */ class WinCacheClassLoader { private $prefix; /** * The class loader object being decorated. * * @var \Symfony\Component\ClassLoader\ClassLoader * A class loader object that implements the findFile() method. */ protected $decorated; /** * Constructor. * * @param string $prefix The WinCache namespace prefix to use. * @param object $decorated A class loader object that implements the findFile() method. * * @throws \RuntimeException * @throws \InvalidArgumentException */ public function __construct($prefix, $decorated) { if (!extension_loaded('wincache')) { throw new \RuntimeException('Unable to use WinCacheClassLoader as WinCache is not enabled.'); } if (!method_exists($decorated, 'findFile')) { throw new \InvalidArgumentException('The class finder must implement a "findFile" method.'); } $this->prefix = $prefix; $this->decorated = $decorated; } /** * Registers this instance as an autoloader. * * @param Boolean $prepend Whether to prepend the autoloader or not */ public function register($prepend = false) { spl_autoload_register(array($this, 'loadClass'), true, $prepend); } /** * Unregisters this instance as an autoloader. */ public function unregister() { spl_autoload_unregister(array($this, 'loadClass')); } /** * Loads the given class or interface. * * @param string $class The name of the class * * @return Boolean|null True, if loaded */ public function loadClass($class) { if ($file = $this->findFile($class)) { require $file; return true; } } /** * Finds a file by class name while caching lookups to WinCache. * * @param string $class A class name to resolve to file * * @return string|null */ public function findFile($class) { if (false === $file = wincache_ucache_get($this->prefix.$class)) { wincache_ucache_set($this->prefix.$class, $file = $this->decorated->findFile($class), 0); } return $file; } /** * Passes through all unknown calls onto the decorated object. */ public function __call($method, $args) { return call_user_func_array(array($this->decorated, $method), $args); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\ClassLoader; /** * XcacheClassLoader implements a wrapping autoloader cached in Xcache for PHP 5.3. * * It expects an object implementing a findFile method to find the file. This * allows using it as a wrapper around the other loaders of the component (the * ClassLoader and the UniversalClassLoader for instance) but also around any * other autoloader following this convention (the Composer one for instance) * * $loader = new ClassLoader(); * * // register classes with namespaces * $loader->add('Symfony\Component', __DIR__.'/component'); * $loader->add('Symfony', __DIR__.'/framework'); * * $cachedLoader = new XcacheClassLoader('my_prefix', $loader); * * // activate the cached autoloader * $cachedLoader->register(); * * // eventually deactivate the non-cached loader if it was registered previously * // to be sure to use the cached one. * $loader->unregister(); * * @author Fabien Potencier * @author Kris Wallsmith * @author Kim Hemsø Rasmussen * * @api */ class XcacheClassLoader { private $prefix; private $classFinder; /** * Constructor. * * @param string $prefix A prefix to create a namespace in Xcache * @param object $classFinder An object that implements findFile() method. * * @throws \RuntimeException * @throws \InvalidArgumentException * * @api */ public function __construct($prefix, $classFinder) { if (!extension_loaded('Xcache')) { throw new \RuntimeException('Unable to use XcacheClassLoader as Xcache is not enabled.'); } if (!method_exists($classFinder, 'findFile')) { throw new \InvalidArgumentException('The class finder must implement a "findFile" method.'); } $this->prefix = $prefix; $this->classFinder = $classFinder; } /** * Registers this instance as an autoloader. * * @param Boolean $prepend Whether to prepend the autoloader or not */ public function register($prepend = false) { spl_autoload_register(array($this, 'loadClass'), true, $prepend); } /** * Unregisters this instance as an autoloader. */ public function unregister() { spl_autoload_unregister(array($this, 'loadClass')); } /** * Loads the given class or interface. * * @param string $class The name of the class * * @return Boolean|null True, if loaded */ public function loadClass($class) { if ($file = $this->findFile($class)) { require $file; return true; } } /** * Finds a file by class name while caching lookups to Xcache. * * @param string $class A class name to resolve to file * * @return string|null */ public function findFile($class) { if (xcache_isset($this->prefix.$class)) { $file = xcache_get($this->prefix.$class); } else { xcache_set($this->prefix.$class, $file = $this->classFinder->findFile($class)); } return $file; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher; use Symfony\Component\DependencyInjection\ContainerInterface; /** * Lazily loads listeners and subscribers from the dependency injection * container * * @author Fabien Potencier * @author Bernhard Schussek * @author Jordan Alliot */ class ContainerAwareEventDispatcher extends EventDispatcher { /** * The container from where services are loaded * @var ContainerInterface */ private $container; /** * The service IDs of the event listeners and subscribers * @var array */ private $listenerIds = array(); /** * The services registered as listeners * @var array */ private $listeners = array(); /** * Constructor. * * @param ContainerInterface $container A ContainerInterface instance */ public function __construct(ContainerInterface $container) { $this->container = $container; } /** * Adds a service as event listener * * @param string $eventName Event for which the listener is added * @param array $callback The service ID of the listener service & the method * name that has to be called * @param integer $priority The higher this value, the earlier an event listener * will be triggered in the chain. * Defaults to 0. * * @throws \InvalidArgumentException */ public function addListenerService($eventName, $callback, $priority = 0) { if (!is_array($callback) || 2 !== count($callback)) { throw new \InvalidArgumentException('Expected an array("service", "method") argument'); } $this->listenerIds[$eventName][] = array($callback[0], $callback[1], $priority); } public function removeListener($eventName, $listener) { $this->lazyLoad($eventName); if (isset($this->listeners[$eventName])) { foreach ($this->listeners[$eventName] as $key => $l) { foreach ($this->listenerIds[$eventName] as $i => $args) { list($serviceId, $method, $priority) = $args; if ($key === $serviceId.'.'.$method) { if ($listener === array($l, $method)) { unset($this->listeners[$eventName][$key]); if (empty($this->listeners[$eventName])) { unset($this->listeners[$eventName]); } unset($this->listenerIds[$eventName][$i]); if (empty($this->listenerIds[$eventName])) { unset($this->listenerIds[$eventName]); } } } } } } parent::removeListener($eventName, $listener); } /** * @see EventDispatcherInterface::hasListeners */ public function hasListeners($eventName = null) { if (null === $eventName) { return (Boolean) count($this->listenerIds) || (Boolean) count($this->listeners); } if (isset($this->listenerIds[$eventName])) { return true; } return parent::hasListeners($eventName); } /** * @see EventDispatcherInterface::getListeners */ public function getListeners($eventName = null) { if (null === $eventName) { foreach (array_keys($this->listenerIds) as $serviceEventName) { $this->lazyLoad($serviceEventName); } } else { $this->lazyLoad($eventName); } return parent::getListeners($eventName); } /** * Adds a service as event subscriber * * @param string $serviceId The service ID of the subscriber service * @param string $class The service's class name (which must implement EventSubscriberInterface) */ public function addSubscriberService($serviceId, $class) { foreach ($class::getSubscribedEvents() as $eventName => $params) { if (is_string($params)) { $this->listenerIds[$eventName][] = array($serviceId, $params, 0); } elseif (is_string($params[0])) { $this->listenerIds[$eventName][] = array($serviceId, $params[0], isset($params[1]) ? $params[1] : 0); } else { foreach ($params as $listener) { $this->listenerIds[$eventName][] = array($serviceId, $listener[0], isset($listener[1]) ? $listener[1] : 0); } } } } /** * {@inheritDoc} * * Lazily loads listeners for this event from the dependency injection * container. * * @throws \InvalidArgumentException if the service is not defined */ public function dispatch($eventName, Event $event = null) { $this->lazyLoad($eventName); return parent::dispatch($eventName, $event); } public function getContainer() { return $this->container; } /** * Lazily loads listeners for this event from the dependency injection * container. * * @param string $eventName The name of the event to dispatch. The name of * the event is the name of the method that is * invoked on listeners. */ protected function lazyLoad($eventName) { if (isset($this->listenerIds[$eventName])) { foreach ($this->listenerIds[$eventName] as $args) { list($serviceId, $method, $priority) = $args; $listener = $this->container->get($serviceId); $key = $serviceId.'.'.$method; if (!isset($this->listeners[$eventName][$key])) { $this->addListener($eventName, array($listener, $method), $priority); } elseif ($listener !== $this->listeners[$eventName][$key]) { parent::removeListener($eventName, array($this->listeners[$eventName][$key], $method)); $this->addListener($eventName, array($listener, $method), $priority); } $this->listeners[$eventName][$key] = $listener; } } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher\Debug; /** * @author Fabien Potencier */ interface TraceableEventDispatcherInterface { /** * Gets the called listeners. * * @return array An array of called listeners */ public function getCalledListeners(); /** * Gets the not called listeners. * * @return array An array of not called listeners */ public function getNotCalledListeners(); } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher; /** * Event is the base class for classes containing event data. * * This class contains no event data. It is used by events that do not pass * state information to an event handler when an event is raised. * * You can call the method stopPropagation() to abort the execution of * further listeners in your event listener. * * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author Bernhard Schussek * * @api */ class Event { /** * @var Boolean Whether no further event listeners should be triggered */ private $propagationStopped = false; /** * @var EventDispatcher Dispatcher that dispatched this event */ private $dispatcher; /** * @var string This event's name */ private $name; /** * Returns whether further event listeners should be triggered. * * @see Event::stopPropagation * @return Boolean Whether propagation was already stopped for this event. * * @api */ public function isPropagationStopped() { return $this->propagationStopped; } /** * Stops the propagation of the event to further event listeners. * * If multiple event listeners are connected to the same event, no * further event listener will be triggered once any trigger calls * stopPropagation(). * * @api */ public function stopPropagation() { $this->propagationStopped = true; } /** * Stores the EventDispatcher that dispatches this Event * * @param EventDispatcherInterface $dispatcher * * @deprecated Deprecated in 2.4, to be removed in 3.0. The event dispatcher is passed to the listener call. * * @api */ public function setDispatcher(EventDispatcherInterface $dispatcher) { $this->dispatcher = $dispatcher; } /** * Returns the EventDispatcher that dispatches this Event * * @return EventDispatcherInterface * * @deprecated Deprecated in 2.4, to be removed in 3.0. The event dispatcher is passed to the listener call. * * @api */ public function getDispatcher() { return $this->dispatcher; } /** * Gets the event's name. * * @return string * * @deprecated Deprecated in 2.4, to be removed in 3.0. The event name is passed to the listener call. * * @api */ public function getName() { return $this->name; } /** * Sets the event's name property. * * @param string $name The event name. * * @deprecated Deprecated in 2.4, to be removed in 3.0. The event name is passed to the listener call. * * @api */ public function setName($name) { $this->name = $name; } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher; /** * The EventDispatcherInterface is the central point of Symfony's event listener system. * * Listeners are registered on the manager and events are dispatched through the * manager. * * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author Bernhard Schussek * @author Fabien Potencier * @author Jordi Boggiano * @author Jordan Alliot * * @api */ class EventDispatcher implements EventDispatcherInterface { private $listeners = array(); private $sorted = array(); /** * @see EventDispatcherInterface::dispatch * * @api */ public function dispatch($eventName, Event $event = null) { if (null === $event) { $event = new Event(); } $event->setDispatcher($this); $event->setName($eventName); if (!isset($this->listeners[$eventName])) { return $event; } $this->doDispatch($this->getListeners($eventName), $eventName, $event); return $event; } /** * @see EventDispatcherInterface::getListeners */ public function getListeners($eventName = null) { if (null !== $eventName) { if (!isset($this->sorted[$eventName])) { $this->sortListeners($eventName); } return $this->sorted[$eventName]; } foreach (array_keys($this->listeners) as $eventName) { if (!isset($this->sorted[$eventName])) { $this->sortListeners($eventName); } } return $this->sorted; } /** * @see EventDispatcherInterface::hasListeners */ public function hasListeners($eventName = null) { return (Boolean) count($this->getListeners($eventName)); } /** * @see EventDispatcherInterface::addListener * * @api */ public function addListener($eventName, $listener, $priority = 0) { $this->listeners[$eventName][$priority][] = $listener; unset($this->sorted[$eventName]); } /** * @see EventDispatcherInterface::removeListener */ public function removeListener($eventName, $listener) { if (!isset($this->listeners[$eventName])) { return; } foreach ($this->listeners[$eventName] as $priority => $listeners) { if (false !== ($key = array_search($listener, $listeners, true))) { unset($this->listeners[$eventName][$priority][$key], $this->sorted[$eventName]); } } } /** * @see EventDispatcherInterface::addSubscriber * * @api */ public function addSubscriber(EventSubscriberInterface $subscriber) { foreach ($subscriber->getSubscribedEvents() as $eventName => $params) { if (is_string($params)) { $this->addListener($eventName, array($subscriber, $params)); } elseif (is_string($params[0])) { $this->addListener($eventName, array($subscriber, $params[0]), isset($params[1]) ? $params[1] : 0); } else { foreach ($params as $listener) { $this->addListener($eventName, array($subscriber, $listener[0]), isset($listener[1]) ? $listener[1] : 0); } } } } /** * @see EventDispatcherInterface::removeSubscriber */ public function removeSubscriber(EventSubscriberInterface $subscriber) { foreach ($subscriber->getSubscribedEvents() as $eventName => $params) { if (is_array($params) && is_array($params[0])) { foreach ($params as $listener) { $this->removeListener($eventName, array($subscriber, $listener[0])); } } else { $this->removeListener($eventName, array($subscriber, is_string($params) ? $params : $params[0])); } } } /** * Triggers the listeners of an event. * * This method can be overridden to add functionality that is executed * for each listener. * * @param callable[] $listeners The event listeners. * @param string $eventName The name of the event to dispatch. * @param Event $event The event object to pass to the event handlers/listeners. */ protected function doDispatch($listeners, $eventName, Event $event) { foreach ($listeners as $listener) { call_user_func($listener, $event, $eventName, $this); if ($event->isPropagationStopped()) { break; } } } /** * Sorts the internal list of listeners for the given event by priority. * * @param string $eventName The name of the event. */ private function sortListeners($eventName) { $this->sorted[$eventName] = array(); if (isset($this->listeners[$eventName])) { krsort($this->listeners[$eventName]); $this->sorted[$eventName] = call_user_func_array('array_merge', $this->listeners[$eventName]); } } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher; /** * The EventDispatcherInterface is the central point of Symfony's event listener system. * Listeners are registered on the manager and events are dispatched through the * manager. * * @author Bernhard Schussek * * @api */ interface EventDispatcherInterface { /** * Dispatches an event to all registered listeners. * * @param string $eventName The name of the event to dispatch. The name of * the event is the name of the method that is * invoked on listeners. * @param Event $event The event to pass to the event handlers/listeners. * If not supplied, an empty Event instance is created. * * @return Event * * @api */ public function dispatch($eventName, Event $event = null); /** * Adds an event listener that listens on the specified events. * * @param string $eventName The event to listen on * @param callable $listener The listener * @param integer $priority The higher this value, the earlier an event * listener will be triggered in the chain (defaults to 0) * * @api */ public function addListener($eventName, $listener, $priority = 0); /** * Adds an event subscriber. * * The subscriber is asked for all the events he is * interested in and added as a listener for these events. * * @param EventSubscriberInterface $subscriber The subscriber. * * @api */ public function addSubscriber(EventSubscriberInterface $subscriber); /** * Removes an event listener from the specified events. * * @param string|array $eventName The event(s) to remove a listener from * @param callable $listener The listener to remove */ public function removeListener($eventName, $listener); /** * Removes an event subscriber. * * @param EventSubscriberInterface $subscriber The subscriber */ public function removeSubscriber(EventSubscriberInterface $subscriber); /** * Gets the listeners of a specific event or all listeners. * * @param string $eventName The name of the event * * @return array The event listeners for the specified event, or all event listeners by event name */ public function getListeners($eventName = null); /** * Checks whether an event has any registered listeners. * * @param string $eventName The name of the event * * @return Boolean true if the specified event has any listeners, false otherwise */ public function hasListeners($eventName = null); } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher; /** * An EventSubscriber knows himself what events he is interested in. * If an EventSubscriber is added to an EventDispatcherInterface, the manager invokes * {@link getSubscribedEvents} and registers the subscriber as a listener for all * returned events. * * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel * @author Bernhard Schussek * * @api */ interface EventSubscriberInterface { /** * Returns an array of event names this subscriber wants to listen to. * * The array keys are event names and the value can be: * * * The method name to call (priority defaults to 0) * * An array composed of the method name to call and the priority * * An array of arrays composed of the method names to call and respective * priorities, or 0 if unset * * For instance: * * * array('eventName' => 'methodName') * * array('eventName' => array('methodName', $priority)) * * array('eventName' => array(array('methodName1', $priority), array('methodName2')) * * @return array The event names to listen to * * @api */ public static function getSubscribedEvents(); } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher; /** * Event encapsulation class. * * Encapsulates events thus decoupling the observer from the subject they encapsulate. * * @author Drak */ class GenericEvent extends Event implements \ArrayAccess, \IteratorAggregate { /** * Event subject. * * @var mixed usually object or callable */ protected $subject; /** * Array of arguments. * * @var array */ protected $arguments; /** * Encapsulate an event with $subject and $args. * * @param mixed $subject The subject of the event, usually an object. * @param array $arguments Arguments to store in the event. */ public function __construct($subject = null, array $arguments = array()) { $this->subject = $subject; $this->arguments = $arguments; } /** * Getter for subject property. * * @return mixed $subject The observer subject. */ public function getSubject() { return $this->subject; } /** * Get argument by key. * * @param string $key Key. * * @throws \InvalidArgumentException If key is not found. * * @return mixed Contents of array key. */ public function getArgument($key) { if ($this->hasArgument($key)) { return $this->arguments[$key]; } throw new \InvalidArgumentException(sprintf('%s not found in %s', $key, $this->getName())); } /** * Add argument to event. * * @param string $key Argument name. * @param mixed $value Value. * * @return GenericEvent */ public function setArgument($key, $value) { $this->arguments[$key] = $value; return $this; } /** * Getter for all arguments. * * @return array */ public function getArguments() { return $this->arguments; } /** * Set args property. * * @param array $args Arguments. * * @return GenericEvent */ public function setArguments(array $args = array()) { $this->arguments = $args; return $this; } /** * Has argument. * * @param string $key Key of arguments array. * * @return boolean */ public function hasArgument($key) { return array_key_exists($key, $this->arguments); } /** * ArrayAccess for argument getter. * * @param string $key Array key. * * @throws \InvalidArgumentException If key does not exist in $this->args. * * @return mixed */ public function offsetGet($key) { return $this->getArgument($key); } /** * ArrayAccess for argument setter. * * @param string $key Array key to set. * @param mixed $value Value. */ public function offsetSet($key, $value) { $this->setArgument($key, $value); } /** * ArrayAccess for unset argument. * * @param string $key Array key. */ public function offsetUnset($key) { if ($this->hasArgument($key)) { unset($this->arguments[$key]); } } /** * ArrayAccess has argument. * * @param string $key Array key. * * @return boolean */ public function offsetExists($key) { return $this->hasArgument($key); } /** * IteratorAggregate for iterating over the object like an array * * @return \ArrayIterator */ public function getIterator() { return new \ArrayIterator($this->arguments); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher; /** * A read-only proxy for an event dispatcher. * * @author Bernhard Schussek */ class ImmutableEventDispatcher implements EventDispatcherInterface { /** * The proxied dispatcher. * @var EventDispatcherInterface */ private $dispatcher; /** * Creates an unmodifiable proxy for an event dispatcher. * * @param EventDispatcherInterface $dispatcher The proxied event dispatcher. */ public function __construct(EventDispatcherInterface $dispatcher) { $this->dispatcher = $dispatcher; } /** * {@inheritdoc} */ public function dispatch($eventName, Event $event = null) { return $this->dispatcher->dispatch($eventName, $event); } /** * {@inheritdoc} */ public function addListener($eventName, $listener, $priority = 0) { throw new \BadMethodCallException('Unmodifiable event dispatchers must not be modified.'); } /** * {@inheritdoc} */ public function addSubscriber(EventSubscriberInterface $subscriber) { throw new \BadMethodCallException('Unmodifiable event dispatchers must not be modified.'); } /** * {@inheritdoc} */ public function removeListener($eventName, $listener) { throw new \BadMethodCallException('Unmodifiable event dispatchers must not be modified.'); } /** * {@inheritdoc} */ public function removeSubscriber(EventSubscriberInterface $subscriber) { throw new \BadMethodCallException('Unmodifiable event dispatchers must not be modified.'); } /** * {@inheritdoc} */ public function getListeners($eventName = null) { return $this->dispatcher->getListeners($eventName); } /** * {@inheritdoc} */ public function hasListeners($eventName = null) { return $this->dispatcher->hasListeners($eventName); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher\Tests; use Symfony\Component\DependencyInjection\Container; use Symfony\Component\DependencyInjection\Scope; use Symfony\Component\EventDispatcher\ContainerAwareEventDispatcher; use Symfony\Component\EventDispatcher\Event; use Symfony\Component\EventDispatcher\EventSubscriberInterface; class ContainerAwareEventDispatcherTest extends \PHPUnit_Framework_TestCase { public function testAddAListenerService() { $event = new Event(); $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); $service ->expects($this->once()) ->method('onEvent') ->with($event) ; $container = new Container(); $container->set('service.listener', $service); $dispatcher = new ContainerAwareEventDispatcher($container); $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); $dispatcher->dispatch('onEvent', $event); } public function testAddASubscriberService() { $event = new Event(); $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\SubscriberService'); $service ->expects($this->once()) ->method('onEvent') ->with($event) ; $container = new Container(); $container->set('service.subscriber', $service); $dispatcher = new ContainerAwareEventDispatcher($container); $dispatcher->addSubscriberService('service.subscriber', 'Symfony\Component\EventDispatcher\Tests\SubscriberService'); $dispatcher->dispatch('onEvent', $event); } public function testPreventDuplicateListenerService() { $event = new Event(); $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); $service ->expects($this->once()) ->method('onEvent') ->with($event) ; $container = new Container(); $container->set('service.listener', $service); $dispatcher = new ContainerAwareEventDispatcher($container); $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent'), 5); $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent'), 10); $dispatcher->dispatch('onEvent', $event); } /** * @expectedException \InvalidArgumentException */ public function testTriggerAListenerServiceOutOfScope() { $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); $scope = new Scope('scope'); $container = new Container(); $container->addScope($scope); $container->enterScope('scope'); $container->set('service.listener', $service, 'scope'); $dispatcher = new ContainerAwareEventDispatcher($container); $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); $container->leaveScope('scope'); $dispatcher->dispatch('onEvent'); } public function testReEnteringAScope() { $event = new Event(); $service1 = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); $service1 ->expects($this->exactly(2)) ->method('onEvent') ->with($event) ; $scope = new Scope('scope'); $container = new Container(); $container->addScope($scope); $container->enterScope('scope'); $container->set('service.listener', $service1, 'scope'); $dispatcher = new ContainerAwareEventDispatcher($container); $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); $dispatcher->dispatch('onEvent', $event); $service2 = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); $service2 ->expects($this->once()) ->method('onEvent') ->with($event) ; $container->enterScope('scope'); $container->set('service.listener', $service2, 'scope'); $dispatcher->dispatch('onEvent', $event); $container->leaveScope('scope'); $dispatcher->dispatch('onEvent'); } public function testHasListenersOnLazyLoad() { $event = new Event(); $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); $container = new Container(); $container->set('service.listener', $service); $dispatcher = new ContainerAwareEventDispatcher($container); $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); $event->setDispatcher($dispatcher); $event->setName('onEvent'); $service ->expects($this->once()) ->method('onEvent') ->with($event) ; $this->assertTrue($dispatcher->hasListeners()); if ($dispatcher->hasListeners('onEvent')) { $dispatcher->dispatch('onEvent'); } } public function testGetListenersOnLazyLoad() { $event = new Event(); $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); $container = new Container(); $container->set('service.listener', $service); $dispatcher = new ContainerAwareEventDispatcher($container); $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); $listeners = $dispatcher->getListeners(); $this->assertTrue(isset($listeners['onEvent'])); $this->assertCount(1, $dispatcher->getListeners('onEvent')); } public function testRemoveAfterDispatch() { $event = new Event(); $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); $container = new Container(); $container->set('service.listener', $service); $dispatcher = new ContainerAwareEventDispatcher($container); $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); $dispatcher->dispatch('onEvent', new Event()); $dispatcher->removeListener('onEvent', array($container->get('service.listener'), 'onEvent')); $this->assertFalse($dispatcher->hasListeners('onEvent')); } public function testRemoveBeforeDispatch() { $event = new Event(); $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); $container = new Container(); $container->set('service.listener', $service); $dispatcher = new ContainerAwareEventDispatcher($container); $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); $dispatcher->removeListener('onEvent', array($container->get('service.listener'), 'onEvent')); $this->assertFalse($dispatcher->hasListeners('onEvent')); } } class Service { public function onEvent(Event $e) { } } class SubscriberService implements EventSubscriberInterface { public static function getSubscribedEvents() { return array( 'onEvent' => 'onEvent', 'onEvent' => array('onEvent', 10), 'onEvent' => array('onEvent'), ); } public function onEvent(Event $e) { } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher\Tests; use Symfony\Component\EventDispatcher\Event; use Symfony\Component\EventDispatcher\EventDispatcher; use Symfony\Component\EventDispatcher\EventSubscriberInterface; class EventDispatcherTest extends \PHPUnit_Framework_TestCase { /* Some pseudo events */ const preFoo = 'pre.foo'; const postFoo = 'post.foo'; const preBar = 'pre.bar'; const postBar = 'post.bar'; /** * @var EventDispatcher */ private $dispatcher; private $listener; protected function setUp() { $this->dispatcher = new EventDispatcher(); $this->listener = new TestEventListener(); } protected function tearDown() { $this->dispatcher = null; $this->listener = null; } public function testInitialState() { $this->assertEquals(array(), $this->dispatcher->getListeners()); $this->assertFalse($this->dispatcher->hasListeners(self::preFoo)); $this->assertFalse($this->dispatcher->hasListeners(self::postFoo)); } public function testAddListener() { $this->dispatcher->addListener('pre.foo', array($this->listener, 'preFoo')); $this->dispatcher->addListener('post.foo', array($this->listener, 'postFoo')); $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); $this->assertTrue($this->dispatcher->hasListeners(self::postFoo)); $this->assertCount(1, $this->dispatcher->getListeners(self::preFoo)); $this->assertCount(1, $this->dispatcher->getListeners(self::postFoo)); $this->assertCount(2, $this->dispatcher->getListeners()); } public function testGetListenersSortsByPriority() { $listener1 = new TestEventListener(); $listener2 = new TestEventListener(); $listener3 = new TestEventListener(); $listener1->name = '1'; $listener2->name = '2'; $listener3->name = '3'; $this->dispatcher->addListener('pre.foo', array($listener1, 'preFoo'), -10); $this->dispatcher->addListener('pre.foo', array($listener2, 'preFoo'), 10); $this->dispatcher->addListener('pre.foo', array($listener3, 'preFoo')); $expected = array( array($listener2, 'preFoo'), array($listener3, 'preFoo'), array($listener1, 'preFoo'), ); $this->assertSame($expected, $this->dispatcher->getListeners('pre.foo')); } public function testGetAllListenersSortsByPriority() { $listener1 = new TestEventListener(); $listener2 = new TestEventListener(); $listener3 = new TestEventListener(); $listener4 = new TestEventListener(); $listener5 = new TestEventListener(); $listener6 = new TestEventListener(); $this->dispatcher->addListener('pre.foo', $listener1, -10); $this->dispatcher->addListener('pre.foo', $listener2); $this->dispatcher->addListener('pre.foo', $listener3, 10); $this->dispatcher->addListener('post.foo', $listener4, -10); $this->dispatcher->addListener('post.foo', $listener5); $this->dispatcher->addListener('post.foo', $listener6, 10); $expected = array( 'pre.foo' => array($listener3, $listener2, $listener1), 'post.foo' => array($listener6, $listener5, $listener4), ); $this->assertSame($expected, $this->dispatcher->getListeners()); } public function testDispatch() { $this->dispatcher->addListener('pre.foo', array($this->listener, 'preFoo')); $this->dispatcher->addListener('post.foo', array($this->listener, 'postFoo')); $this->dispatcher->dispatch(self::preFoo); $this->assertTrue($this->listener->preFooInvoked); $this->assertFalse($this->listener->postFooInvoked); $this->assertInstanceOf('Symfony\Component\EventDispatcher\Event', $this->dispatcher->dispatch('noevent')); $this->assertInstanceOf('Symfony\Component\EventDispatcher\Event', $this->dispatcher->dispatch(self::preFoo)); $event = new Event(); $return = $this->dispatcher->dispatch(self::preFoo, $event); $this->assertEquals('pre.foo', $event->getName()); $this->assertSame($event, $return); } public function testDispatchForClosure() { $invoked = 0; $listener = function () use (&$invoked) { $invoked++; }; $this->dispatcher->addListener('pre.foo', $listener); $this->dispatcher->addListener('post.foo', $listener); $this->dispatcher->dispatch(self::preFoo); $this->assertEquals(1, $invoked); } public function testStopEventPropagation() { $otherListener = new TestEventListener(); // postFoo() stops the propagation, so only one listener should // be executed // Manually set priority to enforce $this->listener to be called first $this->dispatcher->addListener('post.foo', array($this->listener, 'postFoo'), 10); $this->dispatcher->addListener('post.foo', array($otherListener, 'preFoo')); $this->dispatcher->dispatch(self::postFoo); $this->assertTrue($this->listener->postFooInvoked); $this->assertFalse($otherListener->postFooInvoked); } public function testDispatchByPriority() { $invoked = array(); $listener1 = function () use (&$invoked) { $invoked[] = '1'; }; $listener2 = function () use (&$invoked) { $invoked[] = '2'; }; $listener3 = function () use (&$invoked) { $invoked[] = '3'; }; $this->dispatcher->addListener('pre.foo', $listener1, -10); $this->dispatcher->addListener('pre.foo', $listener2); $this->dispatcher->addListener('pre.foo', $listener3, 10); $this->dispatcher->dispatch(self::preFoo); $this->assertEquals(array('3', '2', '1'), $invoked); } public function testRemoveListener() { $this->dispatcher->addListener('pre.bar', $this->listener); $this->assertTrue($this->dispatcher->hasListeners(self::preBar)); $this->dispatcher->removeListener('pre.bar', $this->listener); $this->assertFalse($this->dispatcher->hasListeners(self::preBar)); $this->dispatcher->removeListener('notExists', $this->listener); } public function testAddSubscriber() { $eventSubscriber = new TestEventSubscriber(); $this->dispatcher->addSubscriber($eventSubscriber); $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); $this->assertTrue($this->dispatcher->hasListeners(self::postFoo)); } public function testAddSubscriberWithPriorities() { $eventSubscriber = new TestEventSubscriber(); $this->dispatcher->addSubscriber($eventSubscriber); $eventSubscriber = new TestEventSubscriberWithPriorities(); $this->dispatcher->addSubscriber($eventSubscriber); $listeners = $this->dispatcher->getListeners('pre.foo'); $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); $this->assertCount(2, $listeners); $this->assertInstanceOf('Symfony\Component\EventDispatcher\Tests\TestEventSubscriberWithPriorities', $listeners[0][0]); } public function testAddSubscriberWithMultipleListeners() { $eventSubscriber = new TestEventSubscriberWithMultipleListeners(); $this->dispatcher->addSubscriber($eventSubscriber); $listeners = $this->dispatcher->getListeners('pre.foo'); $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); $this->assertCount(2, $listeners); $this->assertEquals('preFoo2', $listeners[0][1]); } public function testRemoveSubscriber() { $eventSubscriber = new TestEventSubscriber(); $this->dispatcher->addSubscriber($eventSubscriber); $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); $this->assertTrue($this->dispatcher->hasListeners(self::postFoo)); $this->dispatcher->removeSubscriber($eventSubscriber); $this->assertFalse($this->dispatcher->hasListeners(self::preFoo)); $this->assertFalse($this->dispatcher->hasListeners(self::postFoo)); } public function testRemoveSubscriberWithPriorities() { $eventSubscriber = new TestEventSubscriberWithPriorities(); $this->dispatcher->addSubscriber($eventSubscriber); $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); $this->dispatcher->removeSubscriber($eventSubscriber); $this->assertFalse($this->dispatcher->hasListeners(self::preFoo)); } public function testRemoveSubscriberWithMultipleListeners() { $eventSubscriber = new TestEventSubscriberWithMultipleListeners(); $this->dispatcher->addSubscriber($eventSubscriber); $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); $this->assertCount(2, $this->dispatcher->getListeners(self::preFoo)); $this->dispatcher->removeSubscriber($eventSubscriber); $this->assertFalse($this->dispatcher->hasListeners(self::preFoo)); } public function testEventReceivesTheDispatcherInstance() { $this->dispatcher->addListener('test', function ($event) use (&$dispatcher) { $dispatcher = $event->getDispatcher(); }); $this->dispatcher->dispatch('test'); $this->assertSame($this->dispatcher, $dispatcher); } public function testEventReceivesTheDispatcherInstanceAsArgument() { $listener = new TestWithDispatcher(); $this->dispatcher->addListener('test', array($listener, 'foo')); $this->assertNull($listener->name); $this->assertNull($listener->dispatcher); $this->dispatcher->dispatch('test'); $this->assertEquals('test', $listener->name); $this->assertSame($this->dispatcher, $listener->dispatcher); } /** * @see https://bugs.php.net/bug.php?id=62976 * * This bug affects: * - The PHP 5.3 branch for versions < 5.3.18 * - The PHP 5.4 branch for versions < 5.4.8 * - The PHP 5.5 branch is not affected */ public function testWorkaroundForPhpBug62976() { $dispatcher = new EventDispatcher(); $dispatcher->addListener('bug.62976', new CallableClass()); $dispatcher->removeListener('bug.62976', function () {}); $this->assertTrue($dispatcher->hasListeners('bug.62976')); } } class CallableClass { public function __invoke() { } } class TestEventListener { public $preFooInvoked = false; public $postFooInvoked = false; /* Listener methods */ public function preFoo(Event $e) { $this->preFooInvoked = true; } public function postFoo(Event $e) { $this->postFooInvoked = true; $e->stopPropagation(); } } class TestWithDispatcher { public $name; public $dispatcher; public function foo(Event $e, $name, $dispatcher) { $this->name = $name; $this->dispatcher = $dispatcher; } } class TestEventSubscriber implements EventSubscriberInterface { public static function getSubscribedEvents() { return array('pre.foo' => 'preFoo', 'post.foo' => 'postFoo'); } } class TestEventSubscriberWithPriorities implements EventSubscriberInterface { public static function getSubscribedEvents() { return array( 'pre.foo' => array('preFoo', 10), 'post.foo' => array('postFoo'), ); } } class TestEventSubscriberWithMultipleListeners implements EventSubscriberInterface { public static function getSubscribedEvents() { return array('pre.foo' => array( array('preFoo1'), array('preFoo2', 10) )); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher\Tests; use Symfony\Component\EventDispatcher\Event; use Symfony\Component\EventDispatcher\EventDispatcher; /** * Test class for Event. */ class EventTest extends \PHPUnit_Framework_TestCase { /** * @var \Symfony\Component\EventDispatcher\Event */ protected $event; /** * @var \Symfony\Component\EventDispatcher\EventDispatcher */ protected $dispatcher; /** * Sets up the fixture, for example, opens a network connection. * This method is called before a test is executed. */ protected function setUp() { $this->event = new Event(); $this->dispatcher = new EventDispatcher(); } /** * Tears down the fixture, for example, closes a network connection. * This method is called after a test is executed. */ protected function tearDown() { $this->event = null; $this->dispatcher = null; } public function testIsPropagationStopped() { $this->assertFalse($this->event->isPropagationStopped()); } public function testStopPropagationAndIsPropagationStopped() { $this->event->stopPropagation(); $this->assertTrue($this->event->isPropagationStopped()); } public function testSetDispatcher() { $this->event->setDispatcher($this->dispatcher); $this->assertSame($this->dispatcher, $this->event->getDispatcher()); } public function testGetDispatcher() { $this->assertNull($this->event->getDispatcher()); } public function testGetName() { $this->assertNull($this->event->getName()); } public function testSetName() { $this->event->setName('foo'); $this->assertEquals('foo', $this->event->getName()); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher\Tests; use Symfony\Component\EventDispatcher\GenericEvent; /** * Test class for Event. */ class GenericEventTest extends \PHPUnit_Framework_TestCase { /** * @var GenericEvent */ private $event; private $subject; /** * Prepares the environment before running a test. */ protected function setUp() { parent::setUp(); $this->subject = new \stdClass(); $this->event = new GenericEvent($this->subject, array('name' => 'Event'), 'foo'); } /** * Cleans up the environment after running a test. */ protected function tearDown() { $this->subject = null; $this->event = null; parent::tearDown(); } public function testConstruct() { $this->assertEquals($this->event, new GenericEvent($this->subject, array('name' => 'Event'))); } /** * Tests Event->getArgs() */ public function testGetArguments() { // test getting all $this->assertSame(array('name' => 'Event'), $this->event->getArguments()); } public function testSetArguments() { $result = $this->event->setArguments(array('foo' => 'bar')); $this->assertAttributeSame(array('foo' => 'bar'), 'arguments', $this->event); $this->assertSame($this->event, $result); } public function testSetArgument() { $result = $this->event->setArgument('foo2', 'bar2'); $this->assertAttributeSame(array('name' => 'Event', 'foo2' => 'bar2'), 'arguments', $this->event); $this->assertEquals($this->event, $result); } public function testGetArgument() { // test getting key $this->assertEquals('Event', $this->event->getArgument('name')); } /** * @expectedException \InvalidArgumentException */ public function testGetArgException() { $this->event->getArgument('nameNotExist'); } public function testOffsetGet() { // test getting key $this->assertEquals('Event', $this->event['name']); // test getting invalid arg $this->setExpectedException('InvalidArgumentException'); $this->assertFalse($this->event['nameNotExist']); } public function testOffsetSet() { $this->event['foo2'] = 'bar2'; $this->assertAttributeSame(array('name' => 'Event', 'foo2' => 'bar2'), 'arguments', $this->event); } public function testOffsetUnset() { unset($this->event['name']); $this->assertAttributeSame(array(), 'arguments', $this->event); } public function testOffsetIsset() { $this->assertTrue(isset($this->event['name'])); $this->assertFalse(isset($this->event['nameNotExist'])); } public function testHasArgument() { $this->assertTrue($this->event->hasArgument('name')); $this->assertFalse($this->event->hasArgument('nameNotExist')); } public function testGetSubject() { $this->assertSame($this->subject, $this->event->getSubject()); } public function testHasIterator() { $data = array(); foreach ($this->event as $key => $value) { $data[$key] = $value; } $this->assertEquals(array('name' => 'Event'), $data); } } * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher\Tests; use Symfony\Component\EventDispatcher\Event; use Symfony\Component\EventDispatcher\ImmutableEventDispatcher; use Symfony\Component\EventDispatcher\EventSubscriberInterface; /** * @author Bernhard Schussek */ class ImmutableEventDispatcherTest extends \PHPUnit_Framework_TestCase { /** * @var \PHPUnit_Framework_MockObject_MockObject */ private $innerDispatcher; /** * @var ImmutableEventDispatcher */ private $dispatcher; protected function setUp() { $this->innerDispatcher = $this->getMock('Symfony\Component\EventDispatcher\EventDispatcherInterface'); $this->dispatcher = new ImmutableEventDispatcher($this->innerDispatcher); } public function testDispatchDelegates() { $event = new Event(); $this->innerDispatcher->expects($this->once()) ->method('dispatch') ->with('event', $event) ->will($this->returnValue('result')); $this->assertSame('result', $this->dispatcher->dispatch('event', $event)); } public function testGetListenersDelegates() { $this->innerDispatcher->expects($this->once()) ->method('getListeners') ->with('event') ->will($this->returnValue('result')); $this->assertSame('result', $this->dispatcher->getListeners('event')); } public function testHasListenersDelegates() { $this->innerDispatcher->expects($this->once()) ->method('hasListeners') ->with('event') ->will($this->returnValue('result')); $this->assertSame('result', $this->dispatcher->hasListeners('event')); } /** * @expectedException \BadMethodCallException */ public function testAddListenerDisallowed() { $this->dispatcher->addListener('event', function () { return 'foo'; }); } /** * @expectedException \BadMethodCallException */ public function testAddSubscriberDisallowed() { $subscriber = $this->getMock('Symfony\Component\EventDispatcher\EventSubscriberInterface'); $this->dispatcher->addSubscriber($subscriber); } /** * @expectedException \BadMethodCallException */ public function testRemoveListenerDisallowed() { $this->dispatcher->removeListener('event', function () { return 'foo'; }); } /** * @expectedException \BadMethodCallException */ public function testRemoveSubscriberDisallowed() { $subscriber = $this->getMock('Symfony\Component\EventDispatcher\EventSubscriberInterface'); $this->dispatcher->removeSubscriber($subscriber); } } :;դGBMB